我有以下查询,并尝试查看其编写方式是否可以获得最好的性能
UPDATE UserSession
SET
PauseSpan = CASE State WHEN 9 THEN PauseSpan + @SPAN ELSE PauseSpan END,
PauseSpanTotal = CASE State WHEN 9 THEN PauseSpanTotal + @SPAN ELSE PauseSpanTotal END,
PendSpan = CASE State WHEN 5 THEN PendSpan + @SPAN ELSE PendSpan END,
PendSpanTotal = CASE State WHEN 5 THEN PendSpanTotal + @SPAN ELSE PendSpanTotal END
WHERE State = 9 OR State = 5
如您所见,WHERE
语句将导致两种类型的记录被过滤,状态分别为9和5。
由于某些CASE
语句将不被满足,默认的ELSE行为将默认结果为NULL,并且该语句将失败,因为相关列不可为NULL。
所以您可以看到,我已经在每个语句的末尾添加了ELSE,并将列名传递给它,因为我知道这只会导致列保留默认值,以防大小写不匹配。
问题是,这是否会影响性能,因为默认值将被重写到每一列?
https://stackoverflow.com/questions/56724617
复制相似问题