Oracle系列:(15)集合查询
使用并集运算,查询20号部门或30号部门的员工信息 select*fromempwheredeptno=20 union select*fromempwheredeptno=30; 注意: union:二个集合中,如果都有相同的,取其一 union all:二个集合中,如果都有相同的,都取 使用set time/timing on,打开时间的开关 settimeon; settimeoff; 使用set time/timing off,关闭时间的开关 settimingon; settimintoff; 使用交集运算[intersect],查询工资在1000-2000和1500-2500之间的员工信息(方式一) select*fromempwheresalbetween1000and2000 intersect select*fromempwheresalbetween1500and2500; 用where行过滤,查询工资在1000-2000和1500-2500之间的员工信息(方式二) select* fromemp where(salbetween1000and2000)and(salbetween1500and2500); 使用差集运算[minus],查询工资在1000-2000,但不在1500-2500之间的员工信息(方式一) select*fromempwheresalbetween1000and2000 minus select*fromempwheresalbetween1500and2500; 使用where行过滤,查询工资在1000-2000,但不在1500-2500之间的员工信息(方式二) select* fromemp where(salbetween1000and2000)and(salnotbetween1500and2500); 集合查询的细节: 1)集合操作时,必须确保集合列数是相等的 select empno,ename,sal,comm from emp where deptno = 20 union select empno,sal from emp where deptno = 30;错 2)集合操作时,必须确保集合列类型对应相同 select empno,hiredate from emp where deptno = 30;错 3)A union B union C = C union B union A select * from emp where deptno = 10 union select * from emp where deptno = 20 union select * from emp where deptno = 30; 4)当多个集合操作时,结果的列名由第一个集合列名决定 selectempno"编号",ename"姓名",sal"薪水"fromempwheredeptno=20 union selectempno,salfromempwheredeptno=10; |