您的位置:首页 > 教育 > 培训 > 表白网页在线生成网站_房价成交数据官网查询_电商培训大概多少学费_襄阳网站seo

表白网页在线生成网站_房价成交数据官网查询_电商培训大概多少学费_襄阳网站seo

2025/4/3 1:16:40 来源:https://blog.csdn.net/weixin_41826215/article/details/146885531  浏览:    关键词:表白网页在线生成网站_房价成交数据官网查询_电商培训大概多少学费_襄阳网站seo
表白网页在线生成网站_房价成交数据官网查询_电商培训大概多少学费_襄阳网站seo

在 MySQL 中,表连接(Table Join)是将多个表中的数据通过关联条件组合在一起的核心操作

1. 内连接(INNER JOIN)

作用:返回两个表中 满足连接条件 的行(交集)。 

  • 仅返回匹配的行。

  • 如果某行在其中一个表中没有匹配项,则该行不显示。

 

 

 

 2. 左连接(LEFT JOIN / LEFT OUTER JOIN)

 作用:返回左表(LEFT JOIN左侧的表)所有行,右表中 匹配的行,若右表无匹配则填充 NULL

  • 左表数据完整保留,右表无匹配时显示 NULL

  • 常用于查找“左表存在但右表不存在”的数据。

 SELECT employees.name, departments.department_name
FROM employees
LEFT JOIN departments ON employees.department_id = departments.department_id;

 3. 右连接(RIGHT JOIN / RIGHT OUTER JOIN)

 作用:返回右表所有行,左表中 匹配的行,若左表无匹配则填充 NULL

  • 右表数据完整保留,左表无匹配时显示 NULL

  • 用途与 LEFT JOIN 类似,但方向相反。

 SELECT employees.name, departments.department_name
FROM employees
RIGHT JOIN departments ON employees.department_id = departments.department_id;

 4. 全外连接(FULL OUTER JOIN)

  • 返回所有数据,无论是否匹配。

  • 适用于需要同时保留两表全部数据的场景。

 SELECT employees.name, departments.department_name
FROM employees
LEFT JOIN departments ON employees.department_id = departments.department_id
UNION
SELECT employees.name, departments.department_name
FROM employees
RIGHT JOIN departments ON employees.department_id = departments.department_id;

 5. 交叉连接(CROSS JOIN)

  • 结果行数 = 左表行数 × 右表行数。

  • 慎用,可能导致海量数据。

 SELECT products.product_name, categories.category_name
FROM products
CROSS JOIN categories;

 

总结

连接类型描述常用场景
INNER JOIN返回匹配行精确关联查询
LEFT JOIN保留左表全部行查找左表存在但右表缺失的数据
RIGHT JOIN保留右表全部行查找右表存在但左表缺失的数据
FULL OUTER JOIN保留两表全部行(需模拟)合并两表所有数据
CROSS JOIN笛卡尔积生成组合数据(谨慎使用)

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com