zoukankan      html  css  js  c++  java
  • oracle查询包含在子表中的主表数据

     Oracle数据库,查询某表中包含在子表中的数据,子表中数据按特定条件来源于该父表,SQL命令如

    select * from a_table a where a.commandId in (select commandId from b_table where type = 1)

    a_table父表,b_table子表,a和b表都有commandId列,a表的commandId主键关联b表中的外键commandId,要求a表中commandId包含在b表commandId中,且b表的type黑白名单类型为1的数据

    (即查出b表存在的关联的a表的数据)

    也可以用:(仅限于一对一的情况,一对多会出现主表重复的情况)

    select * from a_table a,b_table b where a.commandId =b.commandId (+) and b.commandId is not null and b.type = 1;

    如(一对多出现的问题):

    或者是

    select * from a_table a where exists(select 1 from b_table b where b.commandId =a.commandId where b.type = 1)

    有关in和exists的区别:

    “EXISTS,Oracle会首先检查主查询,然后运行子查询直到它找到第一个匹配项。IN,在执行子查询之前,系统先将主查询挂起,待子查询执行完毕,存放在临时表中以后再执行主查询。

    1、UNION (无重并集):当执行UNION 时,自动去掉结果集中的重复行,并以第一列的结果进行升序排序。

    2、UNION ALL (有重并集):不去掉重复行,并且不对结果集进行排序。

    3、INTERSECT  (交集):取两个结果集的交集,并且以第一列的结果进行升序排列。

          select   id,name,job  from worker 
          INTERSECT
          select  empno,ename,job  fromemp;

    4、MINUS  (差集):只显示在第一个集合中存在,在第二个集合中不存在的数据。并且以第一列的结果进行升序排序。

     

    因此,还有一种写法:

    select * from a_table a where a.commandId in (select commandId from a_table intersect select commandId from b_table)

  • 相关阅读:
    Mysql连接错误:Lost connection to Mysql server at 'waiting for initial communication packet'
    linux基本命令(4) 查看文件相关
    linux基本命令(3) 文件操作相关
    php 验证码不显示
    linux基本命令(2) 修改文件所属人以及权限
    linux 修改开机欢迎文字
    Mysql 自定义HASH索引带来的巨大性能提升
    Maven依赖范围<scope>
    深入理解Java G1垃圾收集器
    Redis EXISTS命令耗时过长case排查
  • 原文地址:https://www.cnblogs.com/likui-bookHouse/p/11532809.html
Copyright © 2011-2022 走看看