• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > Oracle 集操作和exists、in的运用场景

Oracle 集操作和exists、in的运用场景

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了Oracle,操作,exists,运用,场景,操作,定义,多等相关知识,希望本文的分享对您有所帮助

1 集操作 定义:把多个sql的结果集,通过逻辑上的整合运算,拼在一起显示。 集操作缺省下都是按第一个查询的第一列升序排序,当然除了union all: minus:取差集,可用于对两个结果集进行测试 union:取并集,除重 union all:取并集,不剔重 intersect:取交

1 集操作

定义:把多个sql的结果集,通过逻辑上的整合运算,拼在一起显示。

集操作缺省下都是按第一个查询的第一列升序排序,当然除了union all:

minus:取差集,可用于对两个结果集进行测试

union:取并集,除重

union all:取并集,不剔重

intersect:取交集

-

注释:

① union all不排序、不剔重,在效率上比union高。在业务允许下,用union all,则不用union

② 两表作集操作时,字段类型、个数要相同,列的名字可以不必相同;若不一样可补齐,补齐时应注意字段类型,进行显示转换:to_char、to_number、to_date等

③ 多个集操作可通过括号改变sql引擎的执行顺序(缺省sql引擎是自顶向下)

④ union、minus和intersect的共同点:

剔重、排序、不忽略null

⑤ order by只能出现在语句的最后,是对整个集操作结果的排序,列名、别名或者按位置指定,但不能使用第一个select没有出现的列

⑥ 第一个select语句接收列名、别名,或位置记号,查询结果的列名和第一个select语句保持一致

⑦ 可以用于子查询

2 exists、in的运用场景

能不写子查询,尽量不写子查询,而是直接编写多表连接操作。理由如下:

① Oracle CBO在parse阶段,会尽可能把子查询转化为多表连接

② 子查询可读性较低

③ 复杂的逻辑,子查询可能导致Oracle CBO选择错误的执行路径

但如果必须写子查询,到底是in还是exists?exists/not exists专门用于关联子查询。10g之后,Oracle对in的改进,这两者无甚区别。

in和select的技术原理:

㈠ in:先进行子查询,再进行主查询

㈡ exists:先进行主查询,再到子查询中过滤

in和exists的使用建议:

Ⅰ 如果限制性强的条件在子查询,则使用in

Ⅱ 如果限制性强的条件在主查询,则使用exists

可用查询结果集来理解上面这段话,采用最优化匹配原则:拿最小记录匹配大记录。限制性强,则结果集小;反之,则大。

注释:

① 使用exists可以将子查询结果定位常量,不影响查询结果,而且,效率高。

比如:

1.select e.*
2. from emp e 3. where exists 4. (select 1 from dept d 5. where e.deptno=d.deptno and 6. d.dname='SALES') ② not in可能会因为null而改变其行为导致和not exists结果集有出入。然而,在相关子查询下,not in和not exists的结果集是一样的。
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 浅析drop user与delete from mysql.user的区别
  • mysql prompt的用法详解
  • 如何使用索引提高查询速度
  • 深入mysql创建自定义函数与存储过程的详解
  • JDBC数据库的使用操作总结
  • MySQL查询优化:LIMIT 1避免全表扫描提高查询效率
  • MySQL与Oracle的语法区别详细对比
  • 有关mysql中ROW_COUNT()的小例子
  • MySQL 百万级分页优化(Mysql千万级快速分页)
  • 从创建数据库到存储过程与用户自定义函数的小感

相关文章

  • 2018-12-05MySQL 随机密码生成代码
  • 2018-12-05Mysql5.7.17之winx64.zip解压缩版安装配置图文教程
  • 2018-12-05ORACLE查询表最近更改数据的方法
  • 2018-12-05如何修复mysql数据库
  • 2018-12-05SQL语句技巧:按月统计数据
  • 2018-12-05mysql SELECT语句去除某个字段的重复信息
  • 2017-05-11win2003 mysql单向同步配置步骤[已测]
  • 2018-12-05DDL语句的实例详解
  • 2017-05-11mysql中提高Order by语句查询效率的两个思路分析
  • 2018-12-05MySQL登录报错提示ERROR 1045 (28000)错误的解决方法(图文)

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • Oracle9i在Win2k环境下的完全卸载
    • sql 触发器使用例子
    • 配置MySQL主从分离的方法教程
    • 解析Mysql Profiling的使用
    • 如何强制删除或恢复SQLServer正在使用的数据库
    • HBase Coprocessor 剖析与编程实践
    • MYSQL的REPLACE和ON DUPLICATE KEY UPDATE语句介绍解决问题实例
    • CentOS 5.5下安装MySQL 5.5全过程分享
    • InnoDB引擎数据库主从复制同步新的分享
    • 详解MySQL数据库中有关source命令

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有