mysql连接查询左连接,右连接,内连接实例详解

本文主要介绍了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连接查询中索引的重要性

MySQL连接查询中索引的重要性

MySQL连接查询中索引的重要性

© 版权声明
THE END
喜欢就支持一下吧
点赞12 分享