MySQL中join用法解析

2025-10-27
网站建设限时活动促销


MySQL中join用法解析

实例数据库如下:
student表:

mysql> select * from student;+-----------+-----------+------+------+-------+| Sno | Sname | Ssex | Sage | Sdept |+-----------+-----------+------+------+-------+| 201215121 | 李勇 | 男 | 22 | CS || 201215122 | 刘晨 | 女 | 19 | CS || 201215123 | 王敏 | 女 | 18 | MA || 201215125 | 张立 | 男 | 19 | IS || 201215128 | 陈冬 | 男 | 18 | IS || 201215126 | 张成民 | 男 | 18 | CS |+-----------+-----------+------+------+-------+6 rows in set (0.00 sec)

sc表:

mysql> select * from sc;+-----------+------+-------+| Sno | Cno | Grade |+-----------+------+-------+| 201215121 | 1 | 92 || 201215121 | 2 | 85 || 201215121 | 3 | 88 || 201215122 | 2 | 90 || 201215122 | 3 | 80 || 201215128 | 1 | 78 |+-----------+------+-------+6 rows in set (0.00 sec)

LEFT JOIN(左连接)


sql语句如下:

select * from student left join sc on student.Sno=sc.Sno;

运行结果如下:

+-----------+-----------+------+------+-------+-----------+------+-------+| Sno | Sname | Ssex | Sage | Sdept | Sno | Cno | Grade |+-----------+-----------+------+------+-------+-----------+------+-------+| 201215121 | 李勇 | 男 | 22 | CS | 201215121 | 1 | 92 || 201215121 | 李勇 | 男 | 22 | CS | 201215121 | 2 | 85 || 201215121 | 李勇 | 男 | 22 | CS | 201215121 | 3 | 88 || 201215122 | 刘晨 | 女 | 19 | CS | 201215122 | 2 | 90 || 201215122 | 刘晨 | 女 | 19 | CS | 201215122 | 3 | 80 || 201215128 | 陈冬 | 男 | 18 | IS | 201215128 | 1 | 78 || 201215123 | 王敏 | 女 | 18 | MA | NULL | NULL | NULL || 201215125 | 张立 | 男 | 19 | IS | NULL | NULL | NULL || 201215126 | 张成民 | 男 | 18 | CS | NULL | NULL | NULL |+-----------+-----------+------+------+-------+-----------+------+-------+

在此例中left join 是以student表中的记录为基础,student表可以看成左表,sc表可以看成右表,左表中的记录会完全显示出来,加上匹配到的右表,如果左边没有匹配到,则其余部分显示为null。

USING字句

using字句和on字句,类似,但结果略有不同。
例如:

mysql> select student.Sno,Sname,Grade from student left join sc on student.Sno=sc.Sno;+-----------+-----------+-------+| Sno | Sname | Grade |+-----------+-----------+-------+| 201215121 | 李勇 | 92 || 201215121 | 李勇 | 85 || 201215121 | 李勇 | 88 || 201215122 | 刘晨 | 90 || 201215122 | 刘晨 | 80 || 201215128 | 陈冬 | 78 || 201215123 | 王敏 | NULL || 201215125 | 张立 | NULL || 201215126 | 张成民 | NULL |+-----------+-----------+-------+9 rows in set (0.00 sec)

标签: mysql join的用法

本文地址:https://www.lifejia.cn/news/204752.html

免责声明:本站内容仅用于学习参考,信息和图片素材来源于互联网,如内容侵权与违规,请联系我们进行删除,我们将在三个工作日内处理。联系邮箱:cloudinto#qq.com(把#换成@)