- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
什么是更好的 WHERE
条款?
我有一张大 table ,一张 FK 到一张小 table 。我可以直接在FK上搜索,也可以加入FK表并设置WHERE
对连接表的限制。什么更好/更可取?
所以这:
SELECT lt.* FROM LargeTable lt
WHERE lt.SomeId in(12,55)
SELECT lt.* FROM LargeTable lt
INNER JOIN SmallTable st ON lt.SomeId=st.ItemId
WHERE st.Id in(12,55)
Set statistics time on
测试了这个,但我没想到会是这样。谁能解释这里发生了什么?
(946 row(s) affected)
SQL Server Execution Times:
CPU time = 1544 ms, elapsed time = 1580 ms.
(946 row(s) affected)
SQL Server Execution Times:
CPU time = 2636 ms, elapsed time = 366 ms.
SELECT Id
而不是
SELECT *
,那么没有连接的第一个查询的运行时间较短,执行计划中的查询成本是 25%(无连接) vs 75%(有连接的查询)。
最佳答案
根据你的执行计划,这两个查询本质上都是在扫描整个大表中的每一条记录……第二个查询只是在扫描大表之前从小表中找到一小部分记录,这就是为什么相对成本是50 % 对彼此而言。
我建议考虑在 largeTable.SomeId
上建立索引,然后继续第一个查询:
SELECT lt.* FROM LargeTable lt
WHERE lt.SomeId in(12,55)
Your second one gets a parallel plan the first one doesn't
关于大表上的 SQL WHERE -> 先加入小表还是直接在 WHERE 子句中放 FK?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8592840/
几个月前,我做了一个功能,我的应用程序正在等待用户文档并做出相应的响应。直到我对项目进行优化并将其更新到最新版本之前,它一直是一种魅力。 如果存在用户文档,则流将产生该文档并关闭该流。 如果云Fire
Stack Overflow 有几个 examples其中函数首先获得可升级锁,然后通过升级获得独占访问。我的理解是,如果不小心使用,这可能会导致死锁,因为两个线程可能都获得了可升级/共享锁,然后都尝
这个问题在这里已经有了答案: MVC 4 Code First ForeignKeyAttribute on property ... on type ... is not valid (1 个回答
以下是部分代码。我需要在 finally 子句中关闭资源。我需要先调用 closeEntry() 还是 close()?我收到一些错误消息。 Error closing the zipoutjava.
我想使用 RxJS-DOM 观察 mousewheel 事件,这样当第一个事件触发时,我转发它然后删除所有值,直到后续值之间的延迟超过先前指定的持续时间。 我想象的运算符可能看起来像: Rx.DOM.
版本似乎与安装的不同。 我在 npm install 上收到警告 我将二进制文件安装到我的家庭/开发目录中,但它不适用于 sudo。所以我安装了apt。 (注意:我并没有真正安装,我提取并将路径放在/
我正在尝试展示 GAN 网络在某些指定时期的结果。打印当前结果的功能以前与 TF 一起使用。我需要换成 pytorch。 def show_result(G_net, z_, num_epoch, s
我是一名优秀的程序员,十分优秀!