您好,欢迎访问一九零五行业门户网

MySQL 詳解_MySQL

還是先 create table 吧
create table emp(
  id   int not null primary key,
  name     varchar(10)
);
create table emp_dept(
  dept_id       varchar(4) not null,
  emp_id        int not null,
  emp_name      varchar(10),
  primary key (dept_id,emp_id));
insert into emp() values
(1,dennis-1),
(2,dennis-2),
(3,dennis-3),
(4,dennis-4),
(5,dennis-5),
(6,dennis-6),
(7,dennis-7),
(8,dennis-8),
(9,dennis-9),
(10,dennis-10);
insert into emp_dept() values
(r&d,1,dennis-1),
(dev,2,dennis-2),
(r&d,3,dennis-3),
(test,4,dennis-4),
(test,5,dennis-5);
>> 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!
其它类似信息

推荐信息