多表查询的各种连接方式

笛卡尔积

  • 查询出来的数据记录以相乘的形式展现
  • select * from emp, dept;
  • A表记录 * B表记录
    一定要避免这种形式。

内连接

以表中某一字段作为等值连接条件。
内连接,在结果集中只显示通过条件连接在一起的记录。
select * from emp e,dept d where e.depno = d.depno;
select * from emp e inner join dept d on e.deptno = d.depno;

外连接:悬浮记录在结果集中显示

左外链接

跨表查询时左边表里的字段在右边的表里找不到匹配字段的记录也加入到查询结果集
右边表里的字段在左边的表里找不到匹配字段的记录不加入到查询结果集
select * from emp e, dept d where e.depno = d.depno(+),表示在右边的表里面需要构造空数据,也就是左连接。

右外连接

跨表查询时右边表里的字段在右边的表里找不到匹配字段的记录也加入到查询结果集
左边表里的字段在左边的表里找不到匹配字段的记录不加入到查询结果集
select * from emp e, dept d where e.depno(+) = d.depno,表示在左边的表里面需要构造空数据,也就是右连接。

全外连接

跨表查询时左边表里的字段在右边表里找不到匹配字段的记录加入到查询结果集,右边表里的字段在左边表里找不到匹配字段的记录也加入到查询结果集中。

select * from emp e full outer join dept d on e.depno = d.depno;


版权声明:本文为u014685547原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。