【发布时间】:2010-12-05 02:53:58
【问题描述】:
我已经和这个斗争了一段时间了。我有一个存储过程,它接受 3 个用于过滤的参数。如果传入了特定值,我想对其进行过滤。如果传入-1,全部给我。
我试过以下两种方法:
第一种方式:
SELECT field1, field2...etc
FROM my_view
WHERE
parm1 = CASE WHEN @PARM1= -1 THEN parm1 ELSE @PARM1 END
AND parm2 = CASE WHEN @PARM2 = -1 THEN parm2 ELSE @PARM2 END
AND parm3 = CASE WHEN @PARM3 = -1 THEN parm3 ELSE @PARM3 END
第二种方式:
SELECT field1, field2...etc
FROM my_view
WHERE
(@PARM1 = -1 OR parm1 = @PARM1)
AND (@PARM2 = -1 OR parm2 = @PARM2)
AND (@PARM3 = -1 OR parm3 = @PARM3)
我在某处读到第二种方法会短路,如果为真,则永远不会评估第二部分。我的 DBA 说它强制进行表扫描。我尚未对此进行验证,但在某些情况下似乎运行速度较慢。
该视图从中选择的主表有大约 150 万条记录,该视图继续连接大约 15 个其他表以收集大量其他信息。
这两种方法都很慢...从即时到任何地方都需要 2-40 秒,这在我的情况下是完全不可接受的。
是否有更好的方法不涉及将其分解为特定 vs -1 的每个单独案例?
感谢任何帮助。谢谢。
【问题讨论】:
标签: sql-server tsql query-optimization case where-clause