网站推广.NET

网站推广.NET

MySQL中join用法解析

来源:互联网


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的用法