left join on and 與 left join on where的區別

數據庫在經過鏈接兩張或多張表來返回記錄時,都會生成一張中間的臨時表,而後再將這張臨時表返回給用戶。mysql

      在使用left jion時,onwhere條件的區別以下:sql

1 on條件是在生成臨時表時使用的條件,它無論on中的條件是否爲真,都會返回左邊表中的記錄。數據庫

2where條件是在臨時表生成好後,再對臨時表進行過濾的條件。這時已經沒有left join的含義(必須返回左邊表的記錄)了,條件不爲真的就所有過濾掉。spa

       假設有兩張表:.net

1 tab1orm

id sizeget

1 10it

2 20io

3 30form

2 tab2

size name

10 AAA

20 BBB

20 CCC


兩條SQL:
1select * formtab1 left join tab2 on (tab1.size = tab2.size) where tab2.name=’AAA’
2select * formtab1 left join tab2 on (tab1.size = tab2.size and tab2.name=’AAA’)

第一條SQL的過程:

1、中間表
on條件
tab1.size = tab2.size

tab1.id    tab1.size   tab2.size     tab2.name

1              10                  10              AAA

2             20                    20             BBB

2            20                     20              CCC

3            30                   (null)             (null)

2、再對中間表過濾
where 條件:
tab2.name=’AAA’

tab1.id      tab1.size       tab2.size     tab2.name

1                 10                 10             AAA

第二條SQL的過程:

1、中間表
on條件
tab1.size = tab2.size and tab2.name=’AAA’
(條件不爲真也會返回左表中的記錄)

tab1.id      tab1.size        tab2.size       tab2.name

1              10                    10                  AAA

2              20                  (null)              (null)

3              30                   (null)                (null)

     其實以上結果的關鍵緣由就是left join,right join,full join的特殊性,無論on上的條件是否爲真都會返回leftright表中的記錄full則具備leftright的特性的並集。inner jion沒這個特殊性,則條件放在on中和where中,返回的結果集是相同的。

 

 

mysql>  select * from aaa a left join bbb b on a.id = b.id and b.name = '111111111';
+------+-----------+------+-----------+
| id   | name      | id   | name      |
+------+-----------+------+-----------+
|    1 | 陳亮亮    |    1 | 111111111 |
|    1 | 福特      |    1 | 111111111 |
|    1 | bentian   |    1 | 111111111 |
|    2 | 張雲霞    | NULL | NULL      |
|    3 | 陳小平    | NULL | NULL      |
|    4 | 陳小肥    | NULL | NULL      |
|    2 | 寶馬      | NULL | NULL      |
|    3 | 奔馳      | NULL | NULL      |
|    4 | 奧迪      | NULL | NULL      |
|    2 | dazong    | NULL | NULL      |
|    5 | ben       | NULL | NULL      |
|    6 | da        | NULL | NULL      |
+------+-----------+------+-----------+
12 rows in set (0.01 sec)

mysql>  select * from aaa a left join bbb b on a.id = b.id where b.name = '111111111';
+------+-----------+------+-----------+
| id   | name      | id   | name      |
+------+-----------+------+-----------+
|    1 | 陳亮亮    |    1 | 111111111 |
|    1 | 福特      |    1 | 111111111 |
|    1 | bentian   |    1 | 111111111 |
+------+-----------+------+-----------+
3 rows in set (0.00 sec)

mysql>  select * from aaa a left join bbb b on a.id = b.id where a.name = 'bentian';
+------+---------+------+-----------+
| id   | name    | id   | name      |
+------+---------+------+-----------+
|    1 | bentian |    1 | 111111111 |
+------+---------+------+-----------+
1 row in set (0.00 sec)

 

mysql> select * from aaa;+------+-----------+| id   | name      |+------+-----------+|    1 | 陳亮亮    ||    2 | 張雲霞    ||    3 | 陳小平    ||    4 | 陳小肥    ||    1 | 福特      ||    2 | 寶馬      ||    3 | 奔馳      ||    4 | 奧迪      ||    1 | bentian   ||    2 | dazong    ||    5 | ben       ||    6 | da        |+------+-----------+12 rows in set (0.02 sec)mysql> select * from bbb;+------+------------+| id   | name       |+------+------------+|    1 | 111111111  ||    2 | 2222222222 ||    3 | 3333333333 |+------+------------+

相關文章
相關標籤/搜索