mysqljoin查询
时间: 2025-01-02 21:29:56 浏览: 6
### MySQL JOIN 查询详解
#### 内连接 (INNER JOIN)
内连接返回两个表中满足连接条件的记录。只有当两张表中的某个字段相等时才会显示出来。
```sql
SELECT orders.order_id, customers.customer_name
FROM orders
INNER JOIN customers ON orders.customer_id = customers.customer_id;
```
此查询会返回订单表 `orders` 和客户表 `customers` 中具有相同 `customer_id` 的所有记录[^1]。
#### 外连接 (OUTER JOIN)
外连接分为左外连接 (`LEFT OUTER JOIN`) 和右外连接 (`RIGHT OUTER JOIN`)。这些连接不仅返回匹配的数据,还会保留左侧或右侧表中不匹配的数据,在无对应关系的地方填充 NULL 值。
##### 左外连接 (LEFT OUTER JOIN)
左外连接返回左边表所有的记录以及右边表符合条件的记录;如果右边没有对应的记录,则用NULL补充。
```sql
SELECT employees.employee_name, departments.department_name
FROM employees
LEFT OUTER JOIN departments ON employees.department_id = departments.department_id;
```
这条命令即使某些员工未分配部门也会列出所有员工的信息,并且对于那些缺少关联部门的情况给出 null 结果[^2]。
##### 右外连接 (RIGHT OUTER JOIN)
与左外连接相反,右外连接确保右边表格的所有行都被包含进来,而不管左边是否有相应的匹配项。
```sql
SELECT products.product_name, suppliers.supplier_name
FROM products
RIGHT OUTER JOIN suppliers ON products.supplier_id = suppliers.supplier_id;
```
这段代码将展示供应商列表及其供应的产品名称,即便有些供应商当前没有任何产品也依然会被列出来.
#### 交叉连接 (CROSS JOIN)
交叉连接会产生笛卡尔积的结果集,即第一个表每一行同第二个表每行列组合配对形成新的结果集合。需要注意的是,在实际应用中很少单独使用这种类型的联接方式,因为它通常会导致非常庞大的数据量。
```sql
SELECT a.item_name AS itemA, b.item_name AS itemB
FROM items a
CROSS JOIN items b;
```
上述例子展示了如何创建物品之间的所有可能搭配情况,这在特定场景下可能是有用的,但在大多数情况下并不是所期望的行为.
#### 子查询 vs. JOIN
尽管子查询可以在某种程度上完成类似于 JOIN 的功能,特别是在涉及复杂的逻辑运算或是依赖聚合函数的情况下表现良好,但对于简单的多表间一对一或多对一的关系来说,JOIN 更加简洁明了并能提供更好的性能优化机会[^4].
阅读全文