SQL语句的集合运算用法.doc

SQL语句的集合运算用法.doc

ID:57690680

大小:29.50 KB

页数:2页

时间:2020-09-01

SQL语句的集合运算用法.doc_第1页
SQL语句的集合运算用法.doc_第2页
资源描述:

《SQL语句的集合运算用法.doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、SQL语句的MINUS,INTERSECT和UNIONALL SQL语句中的三个关键字:MINUS(减去),INTERSECT(交集)和UNIONALL(并集); 关于集合的概念,中学都应该学过,就不多说了.这三个关键字主要是对数据库的查询结果进行操作,正如其中文含义一样:两个查询,MINUS是从第一个查询结果减去第二个查询结果,如果有相交部分就减去相交部分;否则和第一个查询结果没有区别. INTERSECT是两个查询结果的交集,UNIONALL是两个查询的并集;  虽然同样的功能可以用简单SQL语句来实现,但是性能

2、差别非常大,有人做过实验:made_order共23万笔记录,charge_detail共17万笔记录:   SELECTorder_idFROMmade_order  MINUS  SELECTorder_idFROMcharge_detail耗时:1.14sec    SELECTa.order_idFROMmade_ordera  WHEREa.order_id NOTexists(    SELECTorder_id    FROMcharge_detail    WHEREorder_id=a.order_

3、id  )耗时:18.19sec性能相差15.956倍!因此在遇到这种问题的时候,还是用MINUS,INTERSECT和UNIONALL来解决问题,否则面对业务中随处可见的上百万数据量的查询,数据库服务器还不被咱玩的死翘翘?PS:应用两个集合的相减,相交和相加时,是有严格要求的:1.两个集合的字段必须明确(用*就不行,报错);2.字段类型和顺序相同(名称可以不同),如:集合1的字段1是NUMBER,字段2是VARCHAR,那么集合2的字段1必须也是NUMBER,字段2必须是VARCHAR;3.不能排序,如果要对结果排

4、序,可以在集合运算后,外面再套一个查询,然后排序,如前面的例子可以改成:SELECT*FROM   (SELECTorder_idFROMmade_order  MINUS  SELECTorder_idFROMcharge_detail)ORDERBYORDER_IDASC

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。