• 设为首页
  • 收藏本站
  • 积分充值
  • VIP赞助
  • 手机版
  • 微博
  • 微信
    微信公众号 添加方式:
    1:搜索微信号(888888
    2:扫描左侧二维码
  • 快捷导航
    福建二哥 门户 查看主题

    MySQL之表连接方式(内连接与外连接)

    发布者: 天下网吧 | 发布时间: 2025-6-14 14:29| 查看数: 100| 评论数: 0|帖子模式

    1、表连接的核心概念


    1.1 为什么需要表连接?


    • 问题:两个表的数据需要关联查询(如学生表和成绩表)
    • 笛卡尔积:未指定条件时,两个表的所有记录两两组合(效率低下,结果混乱)
    • 解决方案:通过连接条件筛选有效组合

    2、内连接(INNER JOIN)


    2.1 核心概念


    • 定义:仅返回两表中满足连接条件的记录
    内连接实际上就是利用where子句对两种表形成的笛卡儿积进行筛选,我们前面学习的查询都是内连接,也是在开发过程中使用的最多的连接查询。

    • 语法
    1. select 字段 from 表1 inner join 表2 on 表1.id = 表2.id [and 其他筛选条件];
    复制代码

    • 等价写法
      1. WHERE
      复制代码
      子句隐式内连接
    1. SELECT 字段 FROM 表1, 表2 WHERE 表1.id = 表2.id [and 其他筛选条件];
    复制代码
    2.2 案例

    查询员工及其部门名称
    两者写法不同但是效果一致
    方法一:
    1. ---隐式内连接写法
    2. select *from emp,dept where emp.deptno=dept.deptno;
    复制代码

    方法二:
    1. ---标准内连接写法
    2. select *from dept inner join emp on emp.deptno=dept.deptno;
    复制代码


    3、外连接(OUTER JOIN)

    外连接分为左外连接和右外连接

    3.1 左外连接(LEFT JOIN)

    核心概念

    • 保留规则左表(第一个表)的所有记录,右表无匹配时用
      1. NULL
      复制代码
      填充
    • 语法
    1. select 字段 from 表1 left join 表2 on 链接条件 [and 其他筛选条件];
    复制代码
    案例:查询所有雇员及工资
    1. -- 创建表
    2. CREATE TABLE employees (emp_id INT, emp_name VARCHAR(30));
    3. INSERT INTO employees VALUES (1, 'Alice'),
    4. (2, 'Bob'), (3, 'Charlie'), (4, 'David');

    5. CREATE TABLE salaries (emp_id INT, salary INT);
    6. INSERT INTO salaries VALUES (1, 5000), (2, 6000), (5, 7000);

    7. -- 左外连接查询
    8. select *from employees s1 left join salaries s2 on s1.emp_id=s2.emp_id;
    复制代码
    结果


    3.2 右外连接(RIGHT JOIN)

    核心概念

    • 保留规则右表(第二个表)的所有记录,左表无匹配时用
      1. NULL
      复制代码
      填充
    • 语法
    1. select 字段 from 左表 right join 右表 on 链接条件 [and 其他筛选条件];
    复制代码
    案例:查询所有工资,即使无对应雇员
    1. select *from employees s1 right join salaries s2
    2. on s1.emp_id=s2.emp_id;
    复制代码
    结果


    3.3 左外与右外的等价性
    1. -- 左外连接(保留左表)
    2. SELECT * FROM A LEFT JOIN B ON A.id = B.id;

    3. -- 等价于右外连接(保留右表)
    4. SELECT * FROM B RIGHT JOIN A ON A.id = B.id;
    复制代码
    建议:优先使用左外连接,逻辑更直观。

    4、注意事项


    4.1 ON与WHERE子句的区别


    • ON:用于指定连接条件,影响匹配逻辑。
    • on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录。


    • WHERE:用于过滤已连接后的结果,会过滤掉外连接中的
      1. NULL
      复制代码
      值。
    • where条件是在临时表生成好后,再对临时表进行过滤的条件。这时已经没有left join的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉,on后的条件用来生成左右表关联的临时表,where后的条件对临时表中的记录进行过滤。


    4.2 NULL值的处理

    ifnull()函数

    外连接结果中的
    1. NULL
    复制代码
    表示无匹配记录,需在业务逻辑中处理(如显示“无成绩”)。
    1. select s1.emp_id,emp_name,ifnull(salary,'无成绩')salary
    2. from employees s1 left join salaries s2 on s1.emp_id=s2.emp_id;
    复制代码


    总结

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

    来源:https://www.jb51.net/database/339239rnc.htm
    免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有账号?立即注册

    ×

    最新评论

    QQ Archiver 手机版 小黑屋 福建二哥 ( 闽ICP备2022004717号|闽公网安备35052402000345号 )

    Powered by Discuz! X3.5 © 2001-2023

    快速回复 返回顶部 返回列表