关于内连接、外连接、笛卡尔积

关于内连接、外连接、笛卡尔积内连接 innerjoin 内连接的特性是只显示符合连接条件的记录

大家好,欢迎来到IT知识分享网。 

 内连接 (inner   join)    
内连接的特性是只显示符合连接条件的记录。

 通过比较源表间共享的列的值从多个源表检索行的操作。内联接排除来自不具有与其它源表中的行匹配的行的源表的行。
用join

外连接(outer join)

而外连接就不一样,以左外连接为例(右外连接类似),它除了显示符合连接条件的记录以外,还会显示所有左表中的记录(右外连接就是所有右表中的记录)。

全连接,返回左边表与右边表的所有记录,没有对应的用NULL表示, 用full join

 

关于笛卡尔积、全连接、union的测试

create table test111 (id number,name varchar2(20));

create table test222 (id number,name varchar2(20));

insert into test111 values(111,’aaa’);

insert into test111 values(222,’bbb’);

insert into test111 values(444,’ddd’);

 

insert into test222 values(222,’bbb’);

insert into test222 values(333,’ccc’);

insert into test222 values(444,’eee’);

insert into test222 values(444,’fff’);

笛卡尔积

select * from test111,test222;

       111 aaa                         222 bbb

       111 aaa                         333 ccc

       111 aaa                         444 eee

       111 aaa                         444 fff

       222 bbb                         222 bbb

       222 bbb                         333 ccc

       222 bbb                         444 eee

       222 bbb                         444 fff

       444 ddd                         222 bbb

       444 ddd                         333 ccc

       444 ddd                         444 eee

       444 ddd                         444 fff

全连接

select * from test111 full join test222 on test111.id=test222.id;

       222 bbb                         222 bbb

       444 ddd                         444 eee

       444 ddd                         444 fff

       111 aaa                                  

                                       333 ccc  

等同于

select * from test111 inner join test222 on test111.id=test222.id

union all

select * from test111 left join test222 on test111.id=test222.id where test222.id is null

union all

select * from test111 right join test222 on test111.id=test222.id where test111.id is null;

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/110179.html

(0)
上一篇 2026-02-02 11:26
下一篇 2026-02-02 11:45

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信