zoukankan      html  css  js  c++  java
  • oracle表连接

    ORACLE 8i,9i 表连接方法。

    一般的相等连接:
    select * from a, b where a.id = b.id;
    这个就属于内连接。

    对于外连接:
    Oracle中可以使用“(+) ”来表示,9i可以使用LEFT/RIGHT/FULL OUTER JOIN

    LEFT OUTER JOIN:左外关联
    SELECT e.last_name, e.department_id, d.department_name
    FROM employees e
    LEFT OUTER JOIN departments d
    ON (e.department_id = d.department_id);
    等价于
    SELECT e.last_name, e.department_id, d.department_name
    FROM employees e, departments d
    WHERE e.department_id=d.department_id(+)
    结果为:所有员工及对应部门的记录,包括没有对应部门编号department_id的员工记录。

    RIGHT OUTER JOIN:右外关联
    SELECT e.last_name, e.department_id, d.department_name
    FROM employees e
    RIGHT OUTER JOIN departments d
    ON (e.department_id = d.department_id);
    等价于
    SELECT e.last_name, e.department_id, d.department_name
    FROM employees e, departments d
    WHERE e.department_id(+)=d.department_id
    结果为:所有员工及对应部门的记录,包括没有任何员工的部门记录。

    FULL OUTER JOIN:全外关联
    SELECT e.last_name, e.department_id, d.department_name
    FROM employees e
    FULL OUTER JOIN departments d
    ON (e.department_id = d.department_id);
    结果为:所有员工及对应部门的记录,包括没有对应部门编号department_id的员工记录和没有任何员工的部门记录。

    ORACLE8i是不直接支持完全外连接的语法,也就是说不能在左右两个表上同时加上(+),下面是在ORACLE8i可以参考的完全外连接语法
    select t1.id,t2.id from table1 t1,table t2 where t1.id=t2.id(+)
    union
    select t1.id,t2.id from table1 t1,table t2 where t1.id(+)=t2.id

    连接类型 定义 图示 例子
    内连接 只连接匹配的行  select A.c1,B.c2 from A join B on A.c3 = B.c3;
    左外连接 包含左边表的全部行(不管右边的表中是否存在与它们匹配的行)以及右边表中全部匹配的行  select A.c1,B.c2 from A left join B on A.c3 = B.c3;
    右外连接 包含右边表的全部行(不管左边的表中是否存在与它们匹配的行)以及左边表中全部匹配的行  select A.c1,B.c2 from A right join B on A.c3 = B.c3;
    全外连接 包含左、右两个表的全部行,不管在另一边的表中是否存在与它们匹配的行  select A.c1,B.c2 from A full join B on A.c3 = B.c3;
    (theta)连接 使用等值以外的条件来匹配左、右两个表中的行  select A.c1,B.c2 from A join B on A.c3 != B.c3;
    交叉连接 生成笛卡尔积——它不使用任何匹配或者选取条件,而是直接将一个数据源中的每个行与另一个数据源的每个行一一匹配   select A.c1,B.c2 from A,B;

  • 相关阅读:
    python函数内容
    python读写csv文件
    python正则表达式
    python使用MYSQL数据库
    python简单面试题
    python执行cmd命令
    python详解json模块
    我的自动化测试之路
    测试开发这一年
    招聘测试人员,我在面试什么?
  • 原文地址:https://www.cnblogs.com/liaomin416100569/p/9332084.html
Copyright © 2011-2022 走看看