mysql连接查询

一、mysql常用连接

  • INNER JOIN(内连接,或等值连接):获取两个表中字段匹配关系的记录。
  • LEFT JOIN(左连接):获取左表所有记录,即使右表没有对应匹配的记录。
  • RIGHT JOIN(右连接): 与 LEFT JOIN 相反,用于获取右表所有记录,即使左表没有对应匹配的记录。
mysql> select * from name_address;
+----------+------+----+
| address  | name | id |
+----------+------+----+
| 西北一路 | 张三 |  1 |
| 西北二路 | 李四 |  2 |
| 西北三路 | 王五 |  3 |
+----------+------+----+
3 rows in set

mysql> select * from name_age;
+-----+--------+----+
| age | name   | id |
+-----+--------+----+
| 18  | 张三   |  1 |
| 20  | 王五   |  2 |
| 21  | 路人甲 |  3 |
+-----+--------+----+
3 rows in set

1、INNER JOIN
INNER JOIN与一般的连表查询一致,即使用逗号隔开的查询方式。

mysql> SELECT a.`name`,a.age,b.address FROM name_age a INNER JOIN name_address b WHERE(on) a.`name`=b.`name`;
+------+-----+----------+
| name | age | address  |
+------+-----+----------+
| 张三 | 18  | 西北一路 |
| 王五 | 20  | 西北三路 |
+------+-----+----------+
2 rows in set

2、LEFT JOIN
以左边的数据表为准

mysql> SELECT a.`name`,a.age,b.address FROM name_age a left JOIN name_address b on
 a.`name`=b.`name`;
+--------+-----+----------+
| name   | age | address  |
+--------+-----+----------+
| 张三   | 18  | 西北一路 |
| 王五   | 20  | 西北三路 |
| 路人甲 | 21  | NULL     |
+--------+-----+----------+
3 rows in set

3、RIGHT JOIN
与LEFT JOIN相反,即以右边的数据为准

mysql> SELECT b.`name`,a.age,b.address FROM name_age a right JOIN name_address b on a.`name`=b.`name`;
+------+------+----------+
| name | age  | address  |
+------+------+----------+
| 张三 | 18   | 西北一路 |
| 王五 | 20   | 西北三路 |
| 李四 | NULL | 西北二路 |
+------+------+----------+
3 rows in set

你可能感兴趣的:(mysql)