首页 > 数据库 > MySQL > 正文

mysql连接查询(左连接,右连接,内连接)

2024-07-24 12:51:25
字体:
来源:转载
供稿:网友

一、mysql常用连接

INNER JOIN(内连接,或等值连接):获取两个表中字段匹配关系的记录。 LEFT JOIN(左连接):获取左表所有记录,即使右表没有对应匹配的记录。 RIGHT JOIN(右连接): 与 LEFT JOIN 相反,用于获取右表所有记录,即使左表没有对应匹配的记录。
mysql> select * from name_address;+----------+------+----+| address | name | id |+----------+------+----+| 西北一路 | 张三 | 1 || 西北二路 | 李四 | 2 || 西北三路 | 王五 | 3 |+----------+------+----+3 rows in setmysql> 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 left join,right join,inner join用法分析深入理解mysql之left join 使用详解MySQL Left JOIN时指定NULL列返回特定值详解MySQL表LEFT JOIN左连接与RIGHT JOIN右连接的实例教程MySQL在右表数据不唯一的情况下使用left join的方法解析mysql left( right ) join使用on与where筛选的差异MySQL的LEFT JOIN表连接的进阶学习教程MySQL利用profile分析慢sql详解(group left join效率高于子查询)MySQL中基本的多表连接查询教程详解MySQL中的分组查询与连接查询语句mysql多个left join连接查询用法分析
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表