- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经和这个问题斗争了一段时间了。我有一个存储过程,它接受 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 说它强制进行表扫描。我还没有验证这一点,但在某些情况下它似乎运行得更慢。
该 View 选择的主表大约有 150 万条记录,并且该 View 继续连接大约 15 个其他表以收集大量其他信息。
这两种方法都很慢...从即时到任何地方都需要 2-40 秒,这在我的情况下是完全 Not Acceptable 。
有没有更好的方法,不涉及将其分解为特定 vs -1 的每个单独的情况?
感谢任何帮助。谢谢。
最佳答案
I read somewhere that the second way will short circuit and never eval the second part if true. My DBA said it forces a table scan.
你读错了;它不会短路。你的 DBA 是对的;它不能与查询优化器很好地配合,并且可能会强制进行表扫描。
第一个选项已经是最好的了。您可以选择动态 SQL 或带有各种可能的筛选列组合的长存储过程,以便获得独立的查询计划。您也可以尝试使用“WITH RECOMPILE”选项,但我认为这不会对您有帮助。
关于sql-server - T-SQL Where 子句 Case 语句优化(StoredProc 的可选参数),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1539849/
我正在尝试用 Swift 编写这段 JavaScript 代码:k_combinations 到目前为止,我在 Swift 中有这个: import Foundation import Cocoa e
我是一名优秀的程序员,十分优秀!