mysql> select* fromname_age;
+-----+--------+----+
| age | name| id |
+-----+--------+----+
| 18 | 张三 | 1 |
| 20 | 王五 | 2 |
| 21 | 路人甲 | 3 |
+-----+--------+----+
3 rowsin set
1、INNER JOIN
INNER JOIN与一般的连表查询一致,即使用逗号隔开的查询方式。
mysql> SELECTa.`name`,a.age,b.address FROMname_age a INNERJOIN name_address b WHERE(on) a.`name`=b.`name`;
+------+-----+----------+
| name| age | address |
+------+-----+----------+
| 张三 | 18 | 西北一路 |
| 王五 | 20 | 西北三路 |
+------+-----+----------+
2 rowsin set
2、LEFT JOIN
以左边的数据表为准
mysql> SELECTa.`name`,a.age,b.address FROMname_age a left JOIN name_address b on
a.`name`=b.`name`;
+--------+-----+----------+
| name| age | address |
+--------+-----+----------+
| 张三 | 18 | 西北一路 |
| 王五 | 20 | 西北三路 |
| 路人甲 | 21 | NULL |
+--------+-----+----------+
3 rowsin set
3、RIGHT JOIN
与LEFT JOIN相反,即以右边的数据为准
mysql> SELECTb.`name`,a.age,b.address FROMname_age a right JOIN name_address b ona.`name`=b.`name`;
+------+------+----------+
| name| age | address |
+------+------+----------+
| 张三 | 18 | 西北一路 |
| 王五 | 20 | 西北三路 |
| 李四 | NULL | 西北二路 |
+------+------+----------+
3 rowsin set