网站首页 > 技术文章 正文
原文链接:https://mp.weixin.qq.com/s/BIybb-LS1jIHR4tlHu_2Sg 复制至浏览器,即可查看
(关注“数据和云”公众号,了解更多行业资讯,学习最新数据库知识点!)
摘要:在 Oracle 20c 中,Oracle 增加了对于集合运算符的增强,全部支持了 ANSI SQL 标准的关键字,新增了 EXCEPT 关键字支持。
在 Oracle 20c 中,Oracle 增加了对于集合运算符的增强,全部支持了 ANSI SQL 标准的关键字,新增了 EXCEPT 关键字支持。
- SQL 集合操作支持 ANSI SQL 标准的所有关键字
- 20c 支持了 EXCEPT [ALL] 关键字 (等价 MINUS [ALL])
- 同时 MINUS 和 INTERSECT 支持关键字 ALL.
- 全 ANSI 标准支持,提高了迁移到 Oracle 数据库的兼容性
来看一个简单的测试,创建两个测试表:
[oracle@enmotech ~]$ sqlplus / as sysdba
SQL*Plus: Release 20.0.0.0.0 - Production on Tue Apr 21 07:42:20 2020
Version 20.2.0.0.0
Copyright (c) 1982, 2020, Oracle. All rights reserved.
Connected to:
Oracle Database 20c Enterprise Edition Release 20.0.0.0.0 - Production
Version 20.2.0.0.0
SQL> create table enmo(id number,name varchar2(20));
Table created.
SQL> create table yhem(id number,name varchar2(20));
Table created.
SQL> insert into enmo values(1,'EYGLE');
1 row created.
SQL> insert into yhem values(1,'EYGLE');
1 row created.
SQL> insert into enmo values(2,'KAMUS');
1 row created.
SQL> insert into yhem values(2,'KAMUS');
1 row created.
SQL> insert into yhem values(3,'YANGTINGKUN');
1 row created.
SQL> insert into yhem values(4,'ORA-600');
1 row created.
EXCEPT 和 MINUS 等价比较:
SQL> select * from yhem
2 minus
3 select * from enmo;
ID NAME
---------- --------------------
3 YANGTINGKUN
4 ORA-600
SQL> select * from yhem
2 except
3 select * from enmo;
ID NAME
---------- --------------------
3 YANGTINGKUN
4 ORA-600
SQL> select * from enmo
2 minus
3 select * from yhem;
no rows selected
SQL> insert into enmo values(5,'LAOXIONG');
1 row created.
SQL> select * from enmo
2 minus
3 select * from yhem;
ID NAME
---------- --------------------
5 LAOXIONG
SQL> select * from enmo
2 except
3 select * from yhem;
ID NAME
---------- --------------------
5 LAOXIONG
EXCEPT 通过 ALL 关键字显示所有差异记录,不去重复值:
SQL> insert into yhem values(4,'ORA-600');
1 row created.
SQL> select * from yhem
2 except
3 select * from enmo;
ID NAME
---------- --------------------
3 YANGTINGKUN
4 ORA-600
SQL> select * from yhem
2 except all
3 select * from enmo;
ID NAME
---------- --------------------
3 YANGTINGKUN
4 ORA-600
4 ORA-600
这是 Oracle 20c 中关于 SQL 关键字方面的小增强。
猜你喜欢
- 2024-11-04 Oracle数据库之索引 oracle数据库索引优化
- 2024-11-04 【优技教育】Oracle 19c OCP 082题库(第8题)- 2024年修正版
- 2024-11-04 高级SQL之存储过程 sql中存储过程的用法
- 2024-11-04 Oracle数据库中translate关键字的使用
- 2024-11-04 Oracle保留字和关键字 oracle保留字 字段名冲突
你 发表评论:
欢迎- 621℃几个Oracle空值处理函数 oracle处理null值的函数
- 613℃Oracle分析函数之Lag和Lead()使用
- 602℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 598℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 594℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 586℃【数据统计分析】详解Oracle分组函数之CUBE
- 575℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 563℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)