2011年12月

sql的join分为三种,内连接、外连接、交叉连接。

以下先建2张表,插入一些数据,后续理解起来更方便一些。

create table emp(empno int, name char(20),depart int);

create table depart(dpno int,dpname char(20));

insert into emp values (1,'bell',1);

insert into emp values (2,'smith',2);

insert into emp values (3,'jet',3);

insert into depart values (1,'design');

insert into depart values (2,'database');

insert into depart values (4,'warehouse');

1. 内连接inner join  仅列出两表能按照join条件连接起来的信息,其他的信息不显示

select a.*,b.* from emp a inner join depart b on a.depart=b.dpno;

empno   name         depart       dpno       dpname

----------------------------------------------------------------------

1              bell                1                   1         design

2              smith            2                   2         database

和如下语句得到的信息是一样的:

 select a.*,b.* from emp a,depart b where a.depart=b.dpno;

2. 外连接outer join

(1)左外连接left outer join = left join  显示左表的所有记录,右表符合join条件的信息显示,不符合的置空。

select a.*,b.* from emp a left join depart b on a.depart=b.dpno;

empno   name         depart       dpno       dpname

----------------------------------------------------------------------

1              bell                1                   1         design

2              smith            2                   2         database

3              jet                  3                 

(2)右外连接right outer join = right join 和left join相反,显示右表的所有记录,左表符合join条件的信息显示,不符合的置空。

select a.*,b.* from emp a right join depart b on a.depart=b.dpno;

empno   name         depart       dpno       dpname

----------------------------------------------------------------------

1              bell                1                   1         design

2              smith            2                   2         database

                                                            4         warehouse

(3)全外连接full outer join = full join ,左右两表的信息都全部显示,符合join条件的信息显示,不符合的置空。

select a.*,b.* from emp a full join depart b on a.depart=b.dpno;

empno   name         depart       dpno       dpname

----------------------------------------------------------------------

1              bell                1                   1         design

2              smith            2                   2         database

                                                            4         warehouse

3              jet                  3  

3.交叉连接,也即生成两表的笛卡尔积。得到的记录相当于两表记录的乘积。

select a.*,b.* from emp a cross join depart b ;

empno   name         depart       dpno       dpname

----------------------------------------------------------------------

1              bell                1                   1         design

2              smith            2                   1         design         

3              jet                  3                   1         design

1              bell                1                   2         database

2              smith            2                   2         database         

3              jet                  3                   2         database

1              bell                1                   4         warehouse

2              smith            2                   4         warehouse

3              jet                  3                   4         warehouse

相当于如下语句:

select a.*,b.* from emp a,depart b;

需要注意的是交叉连接后只能跟where,不可以跟on。

如下语句是错的:

select a.*,b.* from emp a cross join depart b on a.depart=b.dpno;

要修改为这样的才正确:

select a.*,b.* from emp a cross join depart b where a.depart=b.dpno;

一般来讲,在大表关联的时候,建议使用inner join或者left join,不建议使用cross join或者where

比如:

select a.*,b.* from emp a,depart b where a.depart=b.dpno ;                                     A     ---不推荐

select a.*,b.* from emp a cross join depart b where a.depart=b.dpno ;                  B     ---不推荐

select a.*,b.* from emp a inner join depart b on a.depart = b.dpno;                         C    ----推荐

这是因为A,B中,sql需要先对两表生成笛卡尔积,然后才根据where后的条件进行判断,而使用C则不需要。所以C较有效率

 

摘自 猫叔的口粮

今天看到这样几幅图片: 心理学中有一些很有意思的图,往往带给我们很多欣喜,也带来很多值得思考的东西。 

下面和大家一起分享: 



首先看一下这幅图,您看到的是什么? 



 

也许您会说,很明显嘛,是只青蛙,那么现在请您换个角度看一下, 

您发现了什么其他的东西吗? 

 



很奇异吧,过程是这样的: 

 

下面我们来看第二幅画: 



 



您可能看到的是个花瓶,也可能看到的是两个女孩的头像, 

关键是您关注的是白色部分还是黑色部分。



下面一幅图,名字叫做“天使与魔鬼”,您看到的是天使还是魔鬼呢? 



 



最后这幅图叫“老妇和少女”,相当经典: 

 

这很明显是位老妪,但是换个角度再看看,有没有不同的发现? 



 

哈,老妪变成了妙龄少女,下面看一下过程: 

 

世界就是如此奇妙,很多时候,我们会碰到不顺心的事,觉得心情郁闷,很烦恼,那么换个角度,换个思路,重新考虑一下,满脸皱纹的老太太就变成美丽的少女,同一件事,也许您看到的就是天使而不是魔鬼。所以,在前面没有路的时候,在遇到不顺心的事的时候,换个角度,你会发现,世界大不一样。愿我们的视野永远有笑没有累,愿我们的心中永远有喜没有悲,愿我们的生活永远美丽似鲜花。