mysql中的left join和join区别
时间: 2023-10-18 16:59:56 浏览: 48
在 MySQL 中,LEFT JOIN 和 JOIN(也被称为 INNER JOIN)是两种不同类型的连接操作。
JOIN 是最基本的连接操作,它返回两个表中匹配的行。它通过比较连接条件(通常是两个表之间的列)来确定匹配的行。如果两个表中的行在连接条件上匹配,那么它们将被返回作为结果集的一部分。
而 LEFT JOIN 是左连接操作,它返回左表中的所有行,以及右表中与左表匹配的行。如果左表的某一行在右表中没有匹配的行,那么结果集中对应右表的列将显示为 NULL 值。
简而言之,JOIN 只返回两个表中匹配的行,而 LEFT JOIN 则返回左表所有行以及与左表匹配的右表行(如果有的话)。
下面是一个示例,假设我们有两个表:users 和 orders。
users 表:
| id | name |
|----|--------|
| 1 | Alice |
| 2 | Bob |
| 3 | Charlie|
orders 表:
| id | user_id | product |
|----|---------|---------|
| 1 | 1 | A |
| 2 | 2 | B |
使用 JOIN 操作:
```
SELECT users.name, orders.product
FROM users
JOIN orders ON users.id = orders.user_id;
```
结果:
| name | product |
|--------|---------|
| Alice | A |
| Bob | B |
使用 LEFT JOIN 操作:
```
SELECT users.name, orders.product
FROM users
LEFT JOIN orders ON users.id = orders.user_id;
```
结果:
| name | product |
|---------|---------|
| Alice | A |
| Bob | B |
| Charlie | NULL |
在上述示例中,JOIN 操作只返回了两个表中匹配的行,而 LEFT JOIN 操作则返回了左表 users 的所有行,并在 orders 表中找到匹配的行。对于 Charlie 这一行来说,在 orders 表中没有匹配的行,所以对应的 product 列显示为 NULL。