【摘要】
小结果集,间接条件{Small Result Set,Indirect Criteria}
典型例子:哪些客户订购了特定产品
可用两类方法表达:
.使用连接,加上distinct去除结果中的重复记录
.使用关联或非关联子查询
首先什么是关联子查询、非关联子查询?
关联子查询:对于外部查询返回的每一行数据,内部查询都要执行一次。另外,在关联子查询中是信息流是双向的。外部查询的每行数据传递一个值给子查询,然后子查询为每一行数据执行一次并返回它的记录。然后,外部查询根据返回的记录做出决策。
非关联子查询:子查询只执行一次,放在内存中
举例:
关联子查询
select c.cust_id,c.cust_type_cd,c.city
from customer c
where 2 = (select count(*)
from account a
where a.cust_id = c.cust_id);
非关联子查询
select c.cust_id,c.cust_type_cd,c.city
from customer c
where c.cust_id in (select cust_id from order where ctime between '2010-1-1' and '2011-1-1')
在MsSql Server 2000下建一个模拟的“哪些客户订购了特定产品”关系表,追加少量数据,执行以下Sql:
Select distinct B.CustomeID From TBMotoOrderDetail A
Inner Join TBMotoOrder B On A.OrderID = B.OrderID
Inner Join TBMotoProduct C On A.ProductID = C.ProductID And C.Name = 'Batmobile'
Select CustomeID From TbMotoOrder Where OrderID in (Select A.OrderID From TBMotoOrderDetail A Inner Join TBMotoProduct C On A.ProductID = C.ProductID Where C.Name = 'Batmobile')
Select CustomeID From TbMotoOrder Where Exists(Select A.OrderID From TBMotoOrderDetail A Inner Join TBMotoProduct C On A.ProductID = C.ProductID Where A.OrderID = TBMotoOrder.OrderID And C.Name = 'Batmobile')
执行计划如下:(点击此图可新开页面浏览大图)
由此看见:少量数据集下,3类执行计划占比都一样;
文中描述:随着Orders表越来越大,(其关联子查询)它的性能就逐渐让我们如坐针毡了
此话测试可在后续补充结论,但从关联子查询和非关联子查询的定义可以基本知道执行顺序
个人还是强调:
第一步先按常规写出正确的sql,再着手如何使用关联子查询或非关联子查询
转载于:https://www.cnblogs.com/GoGoagg/archive/2010/12/31/1922756.html
相关知识
阅读实践三
让阅读绽放个性的花蕾——浅谈个性化阅读的指导
教案三:环境教育的理论与实践谢双玉.ppt
小学综合实践活动方案(通用19篇)
暑期实践活动方案
劳动综合实践活动课说课稿(精选11篇)
让学生在阅读课堂上绽放个性之花——个性化阅读例谈
江南学子三下乡实践报告:天明村花卉市场消费者满意度调查
让花儿自由开放——浅谈实践个性化阅读教学
让个性化阅读之花美丽绽放
网址: 阅读实践三 https://m.huajiangbk.com/newsview104748.html
上一篇: 程序员面试、算法研究、机器学习、 |
下一篇: 虚拟经济与数字经济的关系范文 |