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)

  • 相关阅读:
    mfc窗口,父窗口parentwindow,所有者窗口ownerwindow 区别
    svn冲突问题详解 SVN版本冲突解决详解
    input的on(‘input’,function(0{})事件
    input 输入框两种改变事件的方式
    JSON格式
    AJAX的dataType问题
    什么是跨域请求?
    JSON.parse()和JSON.stringify()使用介绍
    .replace(/-/g,"/")的用法
    docker 实践(一)
  • 原文地址:https://www.cnblogs.com/likui-bookHouse/p/11532809.html
Copyright © 2011-2022 走看看