1. 集合的概念

    与数学中的全集、交集、补集的概念是一样的

  2. 常用的集合运算符

    集合运算符的作用:把两个查询构造为一个联合查询

    1. 全集:求连个查询的全集

    union all:将两个查询的所有数据全部列出,不进行排序,不去掉重复的部分

    SQL> create table t1 as select * from emp where deptno in (,);
    
    Table created.
    
    SQL> create table t2 as select * from emp where deptno in (,);
    
    Table created.
    SQL> select * from t1; EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
    ---------- ---------- --------- ---------- --------- ---------- ---------- ----------
    SMITH CLERK -DEC-
    JONES MANAGER -APR-
    CLARK MANAGER -JUN-
    SCOTT ANALYST -APR-
    KING PRESIDENT -NOV-
    ADAMS CLERK -MAY-
    FORD ANALYST -DEC-
    MILLER CLERK -JAN- rows selected. SQL> select * from t2; EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
    ---------- ---------- --------- ---------- --------- ---------- ---------- ----------
    SMITH CLERK -DEC-
    ALLEN SALESMAN -FEB-
    WARD SALESMAN -FEB-
    JONES MANAGER -APR-
    MARTIN SALESMAN -SEP-
    BLAKE MANAGER -MAY-
    SCOTT ANALYST -APR-
    TURNER SALESMAN -SEP-
    ADAMS CLERK -MAY-
    JAMES CLERK -DEC-
    FORD ANALYST -DEC- rows selected. SQL> select * from t1
    union all
    select * from t2; EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
    ---------- ---------- --------- ---------- --------- ---------- ---------- ----------
    SMITH CLERK -DEC-
    JONES MANAGER -APR-
    CLARK MANAGER -JUN-
    SCOTT ANALYST -APR-
    KING PRESIDENT -NOV-
    ADAMS CLERK -MAY-
    FORD ANALYST -DEC-
    MILLER CLERK -JAN-
    SMITH CLERK -DEC-
    ALLEN SALESMAN -FEB-
    WARD SALESMAN -FEB-
    JONES MANAGER -APR-
    MARTIN SALESMAN -SEP-
    BLAKE MANAGER -MAY-
    SCOTT ANALYST -APR-
    TURNER SALESMAN -SEP-
    ADAMS CLERK -MAY-
    JAMES CLERK -DEC-
    FORD ANALYST -DEC- rows selected.

    union:将两个查询的所有数据进行显示,但是重复的部分只显示一次,而且要按照第一个查询的第一列进行升序排序

    SQL> select * from t1
    union
    select * from t2; EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
    ---------- ---------- --------- ---------- --------- ---------- ---------- ----------
    SMITH CLERK -DEC-
    ALLEN SALESMAN -FEB-
    WARD SALESMAN -FEB-
    JONES MANAGER -APR-
    MARTIN SALESMAN -SEP-
    BLAKE MANAGER -MAY-
    CLARK MANAGER -JUN-
    SCOTT ANALYST -APR-
    KING PRESIDENT -NOV-
    TURNER SALESMAN -SEP-
    ADAMS CLERK -MAY-
    JAMES CLERK -DEC-
    FORD ANALYST -DEC-
    MILLER CLERK -JAN- rows selected.

    union all与union的性能哪个更高?

    union all性能更高:因为union all 不进行排序,也不去重

    2. 交集:INTERSECT

    SQL> select * from t1
    intersect
    select * from t2; EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
    ---------- ---------- --------- ---------- --------- ---------- ---------- ----------
    SMITH CLERK -DEC-
    JONES MANAGER -APR-
    SCOTT ANALYST -APR-
    ADAMS CLERK -MAY-
    FORD ANALYST -DEC-

    3. 补集:MINUS
    查询select * from e2的补集:

    SQL> select * from t1
    minus
    select * from t2; EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
    ---------- ---------- --------- ---------- --------- ---------- ---------- ----------
    CLARK MANAGER -JUN-
    KING PRESIDENT -NOV-
    MILLER CLERK -JAN-
  3. SET运算符规则

    1. 每个查询列表中的表达式的个数和数据类型必须相匹配

    select后面的列的个数必须要一致:

    select empno,ename,deptno,sal from e1
    union all
    select empno,ename,deptno from e2; select empno,ename,deptno,sal from e1
    *
    第 行出现错误:
    ORA-: 查询块具有不正确的结果列数 select empno,ename,deptno,sal from e1
    union all
    select empno,ename,deptno,null from e2 null是可以的
    数据类型必须一致: select empno,ename,deptno,sal from e1
    union all
    select empno,ename,deptno,'abc' from e2 第 行出现错误:
    ORA-: 表达式必须具有与对应表达式相同的数据类型

    2. 可以使用括号来改变执行的顺序

    select * from e1
    intersect
    select * from e2
    union
    select * from e2; ENAME EMPNO SAL DEPTNO
    ------ ----- ----- ------
    ADAMS
    ALLEN
    BLAKE
    FORD
    JAMES
    JONES
    MARTIN
    SCOTT
    SMITH
    TURNER
    WARD 已选择11行。 select * from e1
    intersect
    (select * from e2
    union
    select * from e2); ENAME EMPNO SAL DEPTNO
    ------ ----- ----- ------
    ADAMS
    FORD
    JONES
    SCOTT
    SMITH

    3. ORDER BY 子句的使用:

    除了union all之外,其他的集合运算符都要按照第一个查询的第一列,进行升序

    只可以在语句的最后出现:

    select empno,ename,sal,deptno from e2
    union
    select empno,ename,sal,deptno from e2
    order by ename desc; EMPNO ENAME SAL DEPTNO
    ----- ------ ----- ------
    WARD
    TURNER
    SMITH
    SCOTT
    MARTIN
    JONES
    JAMES
    FORD
    BLAKE
    ALLEN
    ADAMS

    可以使用第一个查询语句的列名、别名、或位置(号)

    select empno,ename name1,sal,deptno from e2
    union
    select empno,ename name2,sal,deptno from e2
    order by name1 desc; EMPNO NAME1 SAL DEPTNO
    ----- ---------- ----- ------
    WARD
    TURNER
    SMITH
    SCOTT
    MARTIN
    JONES
    JAMES
    FORD
    BLAKE
    ALLEN
    ADAMS 已选择11行。 select empno,ename name1,sal,deptno from e2
    union
    select empno,ename name2,sal,deptno from e2
    order by name2 desc; order by name2 desc
    *
    第 行出现错误:
    ORA-: "NAME2": 标识符无效 select empno,ename,sal,deptno from e2
    union
    select empno,to_char(sal) salary, null,deptno from e2
    order by ; EMPNO ENAME SAL DEPTNO
    ----- ------ ----- ------ ADAMS
    ALLEN
    BLAKE
    FORD
    JAMES
    JONES
    MARTIN
    SCOTT
    SMITH
    TURNER
    WARD

    第一个查询语句的列名出现在结果中

    select empno,to_char(sal) salary, null,deptno from e2
    union
    select empno,ename,sal,deptno from e2
    order by
    / EMPNO SALARY NULL DEPTNO
    ----- ---------------------------------------- ---------- ------ ADAMS
    ALLEN
    BLAKE
    FORD
    JAMES
    JONES
    MARTIN
    SCOTT
    SMITH
    TURNER
    WARD

    查询语句的匹配:个数和数据类型的匹配

    select empno,ename,sal,deptno from e1
    union
    select ,to_char(sal),null, from e2; EMPNO ENAME SAL DEPTNO
    ----- ------ ----- ------ SMITH
    JONES
    CLARK
    SCOTT
    KING
    ADAMS
    FORD
    MILLER

集合运算符之全集、交集、补集【weber出品必属精品】的更多相关文章

  1. 全世界最详细的图形化VMware中linux环境下oracle安装(二)【weber出品必属精品】

    <ORACLE 10.2.05版本的升级补丁安装> 首先我们解压 $ unzip p8202632_10205_LINUX.zip 解压后我们会发现多出了个文件夹,他是:Disk1,进入D ...

  2. 全世界最详细的图形化VMware中linux环境下oracle安装(一)【weber出品必属精品】

    安装流程:前期准备工作--->安装ORACLE软件--->安装升级补丁--->安装odbc创建数据库--->安装监听器--->安装EM <前期准备工作> 安装 ...

  3. 控制用户的访问之权限、角色【weber出品必属精品】

    权限的作用 限制用户对数据的访问 权限的分类 1. 系统权限:能够存取数据库的权限 2. 对象权限:操作数据库对象的内容 系统权限  1.1 如何创建用户: SQL> create user t ...

  4. 创建和管理表【weber出品必属精品】

    创建表 必须有 : 1. CREATE TABLE 的权限 SQL> conn /as sysdba 已连接. SQL> create user test default tablespa ...

  5. 使用DML语句【weber出品必属精品】

    DML语句包含以下语法: INSERT:往一个表中增加新行 DELETE:从一个表中删除掉现有的行 UPDATE:更改一个表中现有的行 INSERT语句语法:INSERT INTO TABLE(COL ...

  6. 静默安装ORACLE【weber出品必属精品】

    安装配置系统环境安装linux ,所有服务都不选择,只是选择安装开发工具,不要安装防火墙(当然也可以在后面关闭) 打开终端,执行如下命令,检查安装包,没有的都要安装 make, glibc, liba ...

  7. ORACLE SQL单行函数(三)【weber出品必属精品】

    16.L:代表本地货币符,这个和区域有关.这个时候我们想来显示一下人民币的符号:¥ $ vi .bash_profile ---写入如下内容: export NLS_LANG='SIMPLIFIED ...

  8. 创建存储过程和函数【weber出品必属精品】

    一.什么是存储过程和函数 1. 是被命名的pl/sql块 2. 被称之为pl/sql子程序 3. 与匿名块类似,有块结构: 声明部分是可选的(没有declare关键字) 必须有执行部分 可选的异常处理 ...

  9. 初识数据字典【weber出品必属精品】

    数据字典结构 有两部分组成: 1. 基表:以$结尾的系统表,在创建数据库的时候,oracle自动创建的表 2. 用户可以访问的视图 数据字典的种类 DICTIONARY:简称DICT,所有的数据字典, ...

随机推荐

  1. scala学习笔记——类和对象

    基础语法关于Scala程序,这是非常要注意以下几点. 区分大小写 - Scala是大小写敏感的,这意味着标识Hello 和 hello在Scala中会有不同的含义. 类名 - 对于所有的类名的第一个字 ...

  2. grunt之dev-pro环境切换

    在项目开发过程中和发布阶段需要在开发环境(dev)和生产环境(pro)之间切换,静态文件引用的切换等等. 使用grunt要如何解决上述问题,这里提供一个案列供参考. 用到的grunt插件: 文件合并: ...

  3. itext poi 学习之旅 (1)创建pdf

    从零开始学习itext 创建pdf 1.用到流进行创建的pdf import java.io.File; import java.io.FileOutputStream; import com.ite ...

  4. windows下配置lamp环境(5)---配置MySQL5.6

    开始配置mysql 1.创建配置文件my.ini   1.进入C:\wamp\MySQL   2.把my-default.ini 另存一份:my.ini   3.开始编辑mysql的配置文件,打开my ...

  5. iOS学习之数据请求

    GET请求----同步连接 //GET请求 同步连接 - (void)handleSynchronize:(UIBarButtonItem *)item { //GET请求 //1.创建网址字符串; ...

  6. Method Swizzling以及AOP编程:在运行时进行代码注入-备用

    概述 今天我们主要讨论iOS runtime中的一种黑色技术,称为Method Swizzling.字面上理解Method Swizzling可能比较晦涩难懂,毕竟不是中文,不过你可以理解为“移花接木 ...

  7. windows下重命名一个带有前缀"."dot字符的名字的错误问题

    如果用正常的右键重命名那么肯定会报错的,比如: 有一个名为project的文件,我想把它命名为.project,加了个前缀dot.然后window就报错了,弹出个对话框让“你必须输入一个文件名”.它可 ...

  8. 关于bat文件语法

    @echo offecho 当前盘符:%~d0echo 当前盘符和路径:%~dp0echo 当前批处理全路径:%~f0echo 当前盘符和路径的短文件名格式:%~sdp0echo 当前CMD默认目录: ...

  9. 在docker以FPM-PHP运行php,慢日志导致的BUG分析

    问题描述: 最近将IOS书城容器化,切换流量后.正常的业务测试了一般,都没发现问题.线上的错误监控系统也没有报警,以为迁移工作又告一段落了,暗暗的松了一口气.紧接着,报警邮件来了,查看发现是一个苹果支 ...

  10. Kill 锁,1222:已超过了锁请求超时时段,

    应该是你的表体积很大,处理的时候费事,因为几乎所有数据库操作都需要加或多或少的锁,所以会超时.首先你可以使用select * from sys.sysprocesses where blocked&l ...