Mysql数据库之左连接left join 右连接right join 内连接inner join
时间: 2023-12-09 22:36:45 浏览: 90
以下是Mysql数据库中左连接left join、右连接right join和内连接inner join的介绍和演示:
1. 左连接left join
左连接left join会返回左表中所有的记录,以及右表中符合条件的记录。如果右表中没有符合条件的记录,则返回NULL。
语法:
```
SELECT *
FROM a_table
LEFT JOIN b_table
ON a_table.key = b_table.key;
```
示例:
假设有两个表,一个是学生表students,一个是成绩表scores。学生表中有学生的ID和姓名,成绩表中有学生的ID和成绩。我们需要查询所有学生的姓名和成绩,如果学生没有成绩,则成绩为NULL。
```sql
SELECT students.name, scores.score
FROM students
LEFT JOIN scores
ON students.id = scores.id;
```
2. 右连接right join
右连接right join会返回右表中所有的记录,以及左表中符合条件的记录。如果左表中没有符合条件的记录,则返回NULL。
语法:
```
SELECT *
FROM a_table
RIGHT JOIN b_table
ON a_table.key = b_table.key;
```
示例:
假设有两个表,一个是学生表students,一个是成绩表scores。学生表中有学生的ID和姓名,成绩表中有学生的ID和成绩。我们需要查询所有成绩和对应的学生姓名,如果成绩表中没有对应的学生,则姓名为NULL。
```sql
SELECT students.name, scores.score
FROM students
RIGHT JOIN scores
ON students.id = scores.id;
```
3. 内连接inner join
内连接inner join会返回左右表中都符合条件的记录。
语法:
```
SELECT *
FROM a_table
INNER JOIN b_table
ON a_table.key = b_table.key;
```
示例:
假设有两个表,一个是学生表students,一个是成绩表scores。学生表中有学生的ID和姓名,成绩表中有学生的ID和成绩。我们需要查询所有有成绩的学生的姓名和成绩。
```sql
SELECT students.name, scores.score
FROM students
INNER JOIN scores
ON students.id = scores.id;
```
阅读全文