>> left join
-------------
select a.id,a.name,b.dept_id
from emp a left join emp_dept b on (a.id=b.emp_id);
# 挑出左边的 table emp 中的所有资料,即使 emp_dept 中没有的资料也挑出来,没有的就用 NULL 来显示,
# 也即显示资料是以左边的 table emp 中的资料为基础
mysql> select a.id,a.name,b.dept_id
-> from emp a left join emp_dept b on (a.id=b.emp_id);
+----+-----------+---------+
(专业提供视频软件下载)
id (专业提供视频软件下载)
name (专业提供视频软件下载)
dept_id (专业提供视频软件下载)
+----+-----------+---------+
(专业提供视频软件下载)
1 (专业提供视频软件下载)
Dennis-1 (专业提供视频软件下载)
R&D (专业提供视频软件下载)
(专业提供视频软件下载)
2 (专业提供视频软件下载)
Dennis-2 (专业提供视频软件下载)
DEv (专业提供视频软件下载)
(专业提供视频软件下载)
3 (专业提供视频软件下载)
Dennis-3 (专业提供视频软件下载)
R&D (专业提供视频软件下载)
(专业提供视频软件下载)
4 (专业提供视频软件下载)
Dennis-4 (专业提供视频软件下载)
Test (专业提供视频软件下载)
(专业提供视频软件下载)
5 (专业提供视频软件下载)
Dennis-5 (专业提供视频软件下载)
Test (专业提供视频软件下载)
(专业提供视频软件下载)
6 (专业提供视频软件下载)
Dennis-6 (专业提供视频软件下载)
NULL (专业提供视频软件下载)
(专业提供视频软件下载)
7 (专业提供视频软件下载)
Dennis-7 (专业提供视频软件下载)
NULL (专业提供视频软件下载)
(专业提供视频软件下载)
8 (专业提供视频软件下载)
Dennis-8 (专业提供视频软件下载)
NULL (专业提供视频软件下载)
(专业提供视频软件下载)
9 (专业提供视频软件下载)
Dennis-9 (专业提供视频软件下载)
NULL (专业提供视频软件下载)
(专业提供视频软件下载)
10 (专业提供视频软件下载)
Dennis-10 (专业提供视频软件下载)
NULL (专业提供视频软件下载)
+----+-----------+---------+
# 挑出 table emp 中有而 table emp_dept 中没有的人员资料
select a.id,a.name,b.dept_id
from emp a left join emp_dept b on (a.id=b.emp_id)
where b.dept_id IS NULL;
mysql> select a.id,a.name,b.dept_id
-> from emp a left join emp_dept b on (a.id=b.emp_id)
-> where b.dept_id IS NULL;
+----+-----------+---------+
(专业提供视频软件下载)
id (专业提供视频软件下载)
name (专业提供视频软件下载)
dept_id (专业提供视频软件下载)
+----+-----------+---------+
(专业提供视频软件下载)
6 (专业提供视频软件下载)
Dennis-6 (专业提供视频软件下载)
NULL (专业提供视频软件下载)
(专业提供视频软件下载)
7 (专业提供视频软件下载)
Dennis-7 (专业提供视频软件下载)
NULL (专业提供视频软件下载)
(专业提供视频软件下载)
8 (专业提供视频软件下载)
Dennis-8 (专业提供视频软件下载)
NULL (专业提供视频软件下载)
(专业提供视频软件下载)
9 (专业提供视频软件下载)
Dennis-9 (专业提供视频软件下载)
NULL (专业提供视频软件下载)
(专业提供视频软件下载)
10 (专业提供视频软件下载)
Dennis-10 (专业提供视频软件下载)
NULL (专业提供视频软件下载)
+----+-----------+---------+
# 把 table emp_dept 放在左边的情形(当然以 emp_dept 中的数据为基础来显示资料,emp 中比emp_dept 中多的资料也就不会显示出来了):
select a.id,a.name,b.dept_id
from emp_dept b left join emp a on (a.id=b.emp_id);
mysql> select a.id,a.name,b.dept_id
-> from emp_dept b left join emp a on (a.id=b.emp_id);
+------+----------+---------+
(专业提供视频软件下载)
id (专业提供视频软件下载)
name (专业提供视频软件下载)
dept_id (专业提供视频软件下载)
+------+----------+---------+
(专业提供视频软件下载)
2 (专业提供视频软件下载)
Dennis-2 (专业提供视频软件下载)
DEv (专业提供视频软件下载)
(专业提供视频软件下载)
1 (专业提供视频软件下载)
Dennis-1 (专业提供视频软件下载)
R&D (专业提供视频软件下载)
(专业提供视频软件下载)
3 (专业提供视频软件下载)
Dennis-3 (专业提供视频软件下载)
R&D (专业提供视频软件下载)
(专业提供视频软件下载)
4 (专业提供视频软件下载)
Dennis-4 (专业提供视频软件下载)
Test (专业提供视频软件下载)
(专业提供视频软件下载)
5 (专业提供视频软件下载)
Dennis-5 (专业提供视频软件下载)
Test (专业提供视频软件下载)
+------+----------+---------+
>> right join
---------------
select a.id,a.name,b.dept_id
from emp a right join emp_dept b on (a.id=b.emp_id);
# 挑资料时以右边 table emp_dept 中的资料为基础来显示资料
mysql> select a.id,a.name,b.dept_id
-> from emp a right join emp_dept b on (a.id=b.emp_id);
+------+----------+---------+
(专业提供视频软件下载)
id (专业提供视频软件下载)
name (专业提供视频软件下载)
dept_id (专业提供视频软件下载)
+------+----------+---------+
(专业提供视频软件下载)
2 (专业提供视频软件下载)
Dennis-2 (专业提供视频软件下载)
DEv (专业提供视频软件下载)
(专业提供视频软件下载)
1 (专业提供视频软件下载)
Dennis-1 (专业提供视频软件下载)
R&D (专业提供视频软件下载)
(专业提供视频软件下载)
3 (专业提供视频软件下载)
Dennis-3 (专业提供视频软件下载)
R&D (专业提供视频软件下载)
(专业提供视频软件下载)
4 (专业提供视频软件下载)
Dennis-4 (专业提供视频软件下载)
Test (专业提供视频软件下载)
(专业提供视频软件下载)
5 (专业提供视频软件下载)
Dennis-5 (专业提供视频软件下载)
Test (专业提供视频软件下载)
+------+----------+---------+
5 rows in set (0.00 sec)
# 我们再把 table 的位置交换一下,再用 right join 试试
select a.id,a.name,b.dept_id
from emp_dept b right join emp a on (a.id=b.emp_id);
mysql> select a.id,a.name,b.dept_id
-> from emp_dept b right join emp a on (a.id=b.emp_id);
+----+-----------+---------+
(专业提供视频软件下载)
id (专业提供视频软件下载)
name (专业提供视频软件下载)
dept_id (专业提供视频软件下载)
+----+-----------+---------+
(专业提供视频软件下载)
1 (专业提供视频软件下载)
Dennis-1 (专业提供视频软件下载)
R&D (专业提供视频软件下载)
(专业提供视频软件下载)
2 (专业提供视频软件下载)
Dennis-2 (专业提供视频软件下载)
DEv (专业提供视频软件下载)
(专业提供视频软件下载)
3 (专业提供视频软件下载)
Dennis-3 (专业提供视频软件下载)
R&D (专业提供视频软件下载)
(专业提供视频软件下载)
4 (专业提供视频软件下载)
Dennis-4 (专业提供视频软件下载)
Test (专业提供视频软件下载)
(专业提供视频软件下载)
5 (专业提供视频软件下载)
Dennis-5 (专业提供视频软件下载)
Test (专业提供视频软件下载)
(专业提供视频软件下载)
6 (专业提供视频软件下载)
Dennis-6 (专业提供视频软件下载)
NULL (专业提供视频软件下载)
(专业提供视频软件下载)
7 (专业提供视频软件下载)
Dennis-7 (专业提供视频软件下载)
NULL (专业提供视频软件下载)
(专业提供视频软件下载)
8 (专业提供视频软件下载)
Dennis-8 (专业提供视频软件下载)
NULL (专业提供视频软件下载)
(专业提供视频软件下载)
9 (专业提供视频软件下载)
Dennis-9 (专业提供视频软件下载)
NULL (专业提供视频软件下载)
(专业提供视频软件下载)
10 (专业提供视频软件下载)
Dennis-10 (专业提供视频软件下载)
NULL (专业提供视频软件下载)
+----+-----------+---------+
# 是不是和 left join 一样了?
>> direct join
--------------
# 如果用right join 同不用 Join 直接挑资料是相同的,它等介於以下的指令
select a.id,a.name,b.dept_id
from emp a ,emp_dept b
where a.id=b.emp_id;
mysql> select a.id,a.name,b.dept_id
-> from emp a ,emp_dept b
-> where a.id=b.emp_id;
+----+----------+---------+
(专业提供视频软件下载)
id (专业提供视频软件下载)
name (专业提供视频软件下载)
dept_id (专业提供视频软件下载)
+----+----------+---------+
(专业提供视频软件下载)
2 (专业提供视频软件下载)
Dennis-2 (专业提供视频软件下载)
DEv (专业提供视频软件下载)
(专业提供视频软件下载)
1 (专业提供视频软件下载)
Dennis-1 (专业提供视频软件下载)
R&D (专业提供视频软件下载)
(专业提供视频软件下载)
3 (专业提供视频软件下载)
Dennis-3 (专业提供视频软件下载)
R&D (专业提供视频软件下载)
(专业提供视频软件下载)
4 (专业提供视频软件下载)
Dennis-4 (专业提供视频软件下载)
Test (专业提供视频软件下载)
(专业提供视频软件下载)
5 (专业提供视频软件下载)
Dennis-5 (专业提供视频软件下载)
Test (专业提供视频软件下载)
+----+----------+---------+
怎样,弄明白了吗?
Enjoy it!
……