union和unionall区别

union和unionall区别union 对多个结果集进行并集操作 不包括重复行 同时进行排序 union all 对多个结果集进行并集操作 包括重复行 不进行排序 查询部门小于 30 号的员工信息 和部门大于 20 小于 40 号的员工信息 先查询部门小于 30 号的员工信息 SELECT employees id

大家好,我是讯享网,很高兴认识大家。

查询部门小于30号的员工信息,和部门大于20小于40号的员工信息。

①.先查询部门小于30号的员工信息。
 SELECT employees_id ,last_name ,salary ,department_id FROM employees WHERE department_id < 30; ``` 

讯享网

小于30号部门的员工信息
讯享网

查询部门大于20小于40的员工信息。
讯享网 SELECT employees_id ,last_name ,salary ,department_id FROM employees WHERE department_id BETWEEN 20 and 40;``` 

20到40号部门的员工信息

③.用union连接两张表
 SELECT employees_id ,last_name ,salary ,department_id FROM employees WHERE department_id < 30 UNION SELECT employees_id ,last_name ,salary ,department_id FROM employees WHERE department_id BETWEEN 20 and 40; ``` 

其结果默认排序并去重,两张表都有30号部门信息,结果只出现一次。

union连接两张表

④.下面用union all连接两张表
讯享网 SELECT employees_id ,last_name ,salary ,department_id FROM employees WHERE department_id < 30 UNION ALL SELECT employees_id ,last_name ,salary ,department_id FROM employees WHERE department_id BETWEEN 20 and 40; ``` 

其结果没有去重,也没有排序,排序结果对比下边结果,先去查询20到40的员工信息,在查小于30的员工信息。
union all连接两张表

⑤.对比查询结果
 SELECT employees_id ,last_name ,salary ,department_id FROM employees WHERE department_id BETWEEN 20 and 40 UNION ALL SELECT employees_id ,last_name ,salary ,department_id FROM employees WHERE department_id < 30;``` 

union all去重对比

默认是没有进行排序的。

小讯
上一篇 2025-03-27 10:20
下一篇 2025-03-27 15:43

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/47863.html