首页 >

SQL语句的MINUS,INTERSECT和UNION ALL的解析

数据库|mysql教程SQL语句的MINUS,INTERSECT和UNION ALL的解析
INTERSECT,UNION,MINUS
数据库-mysql教程
SQL语句中的三个关键字:MINUS(减去),INTERSECT(交集)和UNION ALL(并集);
php mvc实例源码,ubuntu搜狗不出汉字,反爬虫贵吗,php merg,seo436lzw
关于集合的概念,中学都应该学过,就不多说了.这三个关键字主要是对数据库的查询结果进行操作,正如其中文含义一样:两个查询,MINUS是从第一个查询结果减去第二个查询结果,如果有相交部分就减去相交部分;否则和第一个查询结果没有区别. INTERSECT是两个查询结果的交集,UNION ALL是两个查询的并集;
高仿卡盟源码,vscode 终端 光标,ubuntu xmap,tomcat 映射 文件,sqlite的表关系,手机左右滑动菜单插件,web前端开发框架实验10,程序员炒股 爬虫,php配置zend,网络seo安卓,youtube镜像网站赚钱吗,全能网页播放器代码,discuz模板 手机模板lzw
SQL语句的MINUS,INTERSECT和UNION ALL的解析
彩票抽奖系统源码,vscode连接,ubuntu 无线网络连接,16g可以安装多少tomcat,sqlite 查询读取,网页设计2018规格,服务器营业执照,千脑网盘插件,java结合前端框架,百度爬虫是,php网站制作教程,火星seo,更换网站后台,网页商品特效,asp 网站模板,jquery 页面左右滚动,access 工资管理系统,php 博客程序lzw
虽然同样的功能可以用简单SQL语句来实现,但是性能差别非常大,有人做过实验:made_order共23万笔记录,charge_detail共17万笔记录:

    SELECT order_id FROM made_order  MINUS  SELECT order_id FROM charge_detail耗时:1.14 sec    SELECT a.order_id FROM made_order a   WHERE a.order_id NOT exists (     SELECT order_id     FROM charge_detail     WHERE order_id = a.order_id   )耗时:18.19 sec

性能相差15.956倍!因此在遇到这种问题的时候,还是用MINUS,INTERSECT和UNION ALL来解决问题,否则面对业务中随处可见的上百万数据量的查询,数据库服务器还不被咱玩的死翘翘?

PS:应用两个集合的相减,相交和相加时,是有严格要求的:1.两个集合的字段必须明确(用*就不行,报错);2.字段类型和顺序相同(名称可以不同),如:集合1的字段1是NUMBER,字段2是VARCHAR,那么集合2的字段1必须也是NUMBER,字段2必须是VARCHAR;3.不能排序,如果要对结果排序,可以在集合运算后,外面再套一个查询,然后排序,如前面的例子可以改成:

SELECT * FROM    (SELECT order_id FROM made_order   MINUS  SELECT order_id FROM charge_detail)ORDER BY ORDER_ID ASC

SQL语句的MINUS,INTERSECT和UNION ALL的解析
  • php-Arrays函数-array
  • php-Arrays函数-array | php-Arrays函数-array ...

    SQL语句的MINUS,INTERSECT和UNION ALL的解析
  • PHP数组函数札记
  • PHP数组函数札记 | PHP数组函数札记 ...

    SQL语句的MINUS,INTERSECT和UNION ALL的解析
  • php-Arrays函数-array
  • php-Arrays函数-array | php-Arrays函数-array ...