MySQL多表查询案例分析(mysql,开发技术)

时间:2024-05-02 02:40:18 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

多表查询

案列说明

笛卡尔积的理解

selectid,department_namefromemployees,departments;#错的selectid,department_id,department_namefromemployeesCROSSJOINdepartments;#错的

每个员工和每个部门匹配了一遍(查出的条目数=id数*department数)

错误原因:缺少连接条件

笛卡尔积的解决

编写连接条件: 表1.列 = 表二.列(若多个表连接,至少要用n-1个连接条件)

selectid,employees.name,department_namefromemployees,departmentsWHEREemployees.name=departments.name;

注:如果要显示的列在要查询的表中名字一样,则要表明,是出自哪个表, eg: employees.name

建议在多表查询时,标明显示的是哪个表的信息 (优化)

优化:可以在FROM后使用表的别名,但是一旦使用别名,后续就一定要都用别名

多表查询的分类

等值连接和非等值连接

  • 等值连接:上述的带有=的

  • 非等值连接:没有=的

selectt1.id,t1.name,t2.gradefromemployeest1,departmentst2WHEREti.salaryBETWEENt2.lowest_salaryANDt2.highest_salary;#非等值

自连接和非自连接

  • 非自链接:表1和表2连接

  • 自链接:表1和自己连接

#显示员工(t1)和其管理者(t2)的基本信息selectt1.id,t1.name,t2.id,t2.namefromemployeest1,employeest2#一个表看作两个表WHEREt1.manage_id=t2.id;#自连接

内连接和外连接

  • 内连接:合并含有同一列的表,结果不包括一个表与另一个表不匹配打的行

  • 外连接:合并含有同一列的表,结果除了内连接的结果还查询不匹配的行

外连接的分类:左外连接(左表多,补右边),右外连接(右表多,补左边),满外连接

SQL92:使用(+)创建连接

内连接:见上

外连接:左表有数据不匹配,在右表加(+);反之,在左表加(+),但是MySQL不支持

WHEREt1.department_id=t2.department_id(+)#左连接

SQL99:使用JOIN...ON的方式

内连接

selectt1.id,t1.name,t2.department_name,t3.environmentfromemployeest1JOINdepartmentst2ONt1.department_id=t2.department_idJOINlocationst3#加入第二个人表ONt2.department_location=t3.department_location;

外连接

使用OUTER JOIN...ON...

  • 左外连接:LEFT OUTER JOIN

  • 右外连接:RIGHT OUTER JOIN

  • 满外连接:FULL OUTER JOIN(MySQL不支持)

selectt1.name,t2.department_name#左外连接fromemployeest1LEFTOUTER(可省略)JOINdepartmentst2ONt1.department_id=t2.department_id;

UMION的使用

合并查询结果

SELECTcolum...FROMtable1UNION(ALL)SELECTcolum...FROMtable2
  • UNION操作符

两个查询结果的并集,去重(效率低)

  • UNION ALL操作符(推荐)

两个查询结果的并集,不去重(效率高)

7种SQL JOINS的实现

MySQL多表查询案例分析

中图(内连接):

selectt1.name,t2.department_namefromemployeest1JOINdepartmentst2ONt1.department_id=t2.department_id;

左上图(左外连接):

selectt1.name,t2.department_namefromemployeest1LEFTJOINdepartmentst2ONt1.department_id=t2.department_id;

右上图(右外连接):

selectt1.name,t2.department_namefromemployeest1RIGHTJOINdepartmentst2ONt1.department_id=t2.department_id;

左中图:

selectt1.name,t2.department_namefromemployeest1LEFTJOINdepartmentst2ONt1.department_id=t2.department_idWHEREt2.department_idISNULL;

右中图:

selectt1.name,t2.department_namefromemployeest1RIGHTJOINdepartmentst2ONt1.department_id=t2.department_idWHEREt1.department_idISNULL;

左下图(满外连接):

#方式一:左上图UNIONALL右中图selectt1.name,t2.department_namefromemployeest1LEFTJOINdepartmentst2ONt1.department_id=t2.department_idUNIONALLselectt1.name,t2.department_namefromemployeest1RIGHTJOINdepartmentst2ONt1.department_id=t2.department_idWHEREt1.department_idISNULL;#方式二:左中图UNIONALL右上图selectt1.name,t2.department_namefromemployeest1LEFTJOINdepartmentst2ONt1.department_id=t2.department_idWHEREt2.department_idISNULLUNIONALLselectt1.name,t2.department_namefromemployeest1RIGHTJOINdepartmentst2ONt1.department_id=t2.department_id;

右下图:

#左中图UNIONALL右中图selectt1.name,t2.department_namefromemployeest1LEFTJOINdepartmentst2ONt1.department_id=t2.department_idWHEREt2.department_idISNULLUNIONALLselectt1.name,t2.department_namefromemployeest1RIGHTJOINdepartmentst2ONt1.department_id=t2.department_idWHEREt1.department_idISNULL;

SQL语法新特性

自然连接

使用关键字:NATURAL JOIN(不灵活),自动查询表中所有相同字段,然后进行等值连接

USING连接(不适用于自连接)

使用关键字:USING(同名字段),将表中相同名字的字段自动等值连接

selectt1.name,t2.department_namefromemployeest1JOINdepartmentst2ONt1.department_id=t2.department_id;等价于selectt1.name,t2.department_namefromemployeest1JOINdepartmentst2USING(department_id);
 </div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
本文:MySQL多表查询案例分析的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:怎么使用Holer通过外网访问本地SpringBoot下一篇:

18 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18