原始問題:
如何使用CASE 語句有選擇地更新記錄在SQL Server 2005中不掃描所有不受影響的rows?
上下文:
以下CASE 語句用於更新dbo.TestStudents 表的LASTNAME 欄位中的特定值:
UPDATE dbo.TestStudents SET LASTNAME = ( CASE WHEN (LASTNAME = 'AAA') THEN 'BBB' WHEN (LASTNAME = 'CCC') THEN 'DDD' WHEN (LASTNAME = 'EEE') THEN 'FFF' ELSE (LASTNAME) END )
雖然語句達到了預期的目的,但ELSE條件需要掃描中的所有行
解決方案:
為避免掃描未受影響的行,可以在語句中添加WHERE 子句來指定應更新哪些行。
UPDATE dbo.TestStudents SET LASTNAME = CASE WHEN LASTNAME = 'AAA' THEN 'BBB' WHEN LASTNAME = 'CCC' THEN 'DDD' WHEN LASTNAME = 'EEE' THEN 'FFF' ELSE LASTNAME END WHERE LASTNAME IN ('AAA', 'CCC', 'EEE')
透過在 WHERE 子句中指定要更新的 LASTNAME 值,該語句僅更新受影響的行,而保留其他行不變。
以上是如何最佳化SQL Server 2005中的CASE語句更新以避免全表掃描?的詳細內容。更多資訊請關注PHP中文網其他相關文章!