Има ли уловка? Да, има -- лявото свързване е форма на външно съединение, докато вътрешните съединения са форма на, добре, вътрешно съединение.
Ето примери, които показват разликата. Ще започнем с основните данни:
mysql> select * from j1;
+----+------------+
| id | thing |
+----+------------+
| 1 | hi |
| 2 | hello |
| 3 | guten tag |
| 4 | ciao |
| 5 | buongiorno |
+----+------------+
mysql> select * from j2;
+----+-----------+
| id | thing |
+----+-----------+
| 1 | bye |
| 3 | tschau |
| 4 | au revoir |
| 6 | so long |
| 7 | tschuessi |
+----+-----------+
И тук ще видим разликата между вътрешно и ляво присъединяване:
mysql> select * from j1 inner join j2 on j1.id = j2.id;
+----+-----------+----+-----------+
| id | thing | id | thing |
+----+-----------+----+-----------+
| 1 | hi | 1 | bye |
| 3 | guten tag | 3 | tschau |
| 4 | ciao | 4 | au revoir |
+----+-----------+----+-----------+
Хм, 3 реда.
mysql> select * from j1 left join j2 on j1.id = j2.id;
+----+------------+------+-----------+
| id | thing | id | thing |
+----+------------+------+-----------+
| 1 | hi | 1 | bye |
| 2 | hello | NULL | NULL |
| 3 | guten tag | 3 | tschau |
| 4 | ciao | 4 | au revoir |
| 5 | buongiorno | NULL | NULL |
+----+------------+------+-----------+
Леле, 5 реда! Какво се случи?
Външни съединения като left join
запазване на редове, които не съвпадат - така че редовете с идентификатор 2 и 5 се запазват от заявката за ляво присъединяване. Останалите колони се попълват с NULL.
С други думи, лявото и вътрешното свързване не са взаимозаменяеми.