MySQL多表连接查询详解

2022-05-15 0 1,079
目录
  • 多表连接查询
    • 内连接
    • 左连接
    • 右连接
  • 子查询
    • 总结

      多表连接查询

      表与表之间的连接分为内连接和外连接

      • 内连接:仅选出两张表互相匹配的记录
      • 外连接:既包括两张表匹配的记录,也包括不匹配的记录,同时外连接又分为左外连接(左连接)和右外连接(右连接)

      内连接

      首先准备两张表

      学生student表

      MySQL多表连接查询详解

      分数score表

      MySQL多表连接查询详解

      内连接:在每个表中找出符合条件的共有记录
      查询student表中的学生姓名和分数

      第一种写法:只使用where

      select a.s_name, b.s_score from student a,score b where a.s_id = b.s_id;

      第二种写法:join … on…

      select a.s_name, b.s_score from student a join score b on a.s_id = b.s_id
      

      第三种写法:inner join … on…

      select a.s_name, b.s_score from student a inner join score b on a.s_id = b.s_id
      

      MySQL多表连接查询详解

      左连接

      左连接:根据左表的记录,在被连接的右表中找出符合条件的记录与之匹配,如果找不到与左表匹配的,用null表示

      第一种写法:left join … on …

      select a.s_name,b.s_score from student a left join score b on a.s_id = b.s_id
      

      第二种写法:left outer join … on …

      select a.s_name,b.s_score from student a left outer join score b on a.s_id = b.s_id
      

      MySQL多表连接查询详解

      右连接

      **右连接:**根据右表的记录,在被连接的左表中找出符合条件的记录与之匹配,如果找不到匹配的,用null表示

      第一种写法:right join … on …

      select a.s_name,b.s_score from student a right join score b on a.s_id = b.s_id;
      

      第二种写法:right outer join … on …

      select a.s_name,b.s_score from student a right outer join score b on a.s_id = b.s_id;
      

      MySQL多表连接查询详解

      子查询

      子查询:是多表连接查询的一种实现方式,在一个select语句的from子句或where子句中嵌套了另一个select语句,外层的select查询语句成为主查询,换句话将就是WHERE或FORM中的查询语句称为子查询

      WHERE子句中的子查询:子查询返回的值作为主查询的查询条件

      FROM子句中的子查询:子查询返回的是一张虚拟的表,主查询从该查询从临时表查询出满足的条件

      总结

      本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注NICE源码的更多内容!

      免责声明:
      1、本网站所有发布的源码、软件和资料均为收集各大资源网站整理而来;仅限用于学习和研究目的,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 不得使用于非法商业用途,不得违反国家法律。否则后果自负!

      2、本站信息来自网络,版权争议与本站无关。一切关于该资源商业行为与www.niceym.com无关。
      如果您喜欢该程序,请支持正版源码、软件,购买注册,得到更好的正版服务。
      如有侵犯你版权的,请邮件与我们联系处理(邮箱:skknet@qq.com),本站将立即改正。

      NICE源码网 MySql MySQL多表连接查询详解 https://www.niceym.com/38590.html