文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL多表查询案例分析

2023-06-29 09:33

关注

本篇内容介绍了“MySQL多表查询案例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

多表查询

案列说明

笛卡尔积的理解

select id,department_namefrom employees,departments;#错的select id,department_id,department_namefrom employees CROSS JOIN departments;#错的

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

错误原因:缺少连接条件

笛卡尔积的解决

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

select id,employees.name,department_name from employees,departmentsWHERE employees.name = departments.name;

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

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

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

多表查询的分类

等值连接和非等值连接

select t1.id,t1.name,t2.gradefrom employees t1,departments t2WHERE ti.salary BETWEEN t2.lowest_salary AND t2.highest_salary ;#非等值

自连接和非自连接

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

内连接和外连接

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

SQL92:使用(+)创建连接

内连接:见上

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

WHERE t1.department_id = t2.department_id(+)#左连接

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

内连接

select t1.id,t1.name,t2.department_name,t3.environmentfrom employees t1 JOIN departments t2ON t1.department_id = t2.department_idJOIN locations t3#加入第二个人表ON t2.department_location = t3.department_location;

外连接

使用OUTER JOIN...ON...

select t1.name,t2.department_name#左外连接from employees t1 LEFT OUTER(可省略) JOIN departments t2ON t1.department_id = t2.department_id;

UMION的使用

合并查询结果

SELECT colum... FROM table1UNION (ALL)SELECT colum... FROM table2

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

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

7种SQL JOINS的实现

MySQL多表查询案例分析

中图(内连接):

select t1.name,t2.department_namefrom employees t1 JOIN departments t2ON t1.department_id = t2.department_id;

左上图(左外连接):

select t1.name,t2.department_namefrom employees t1 LEFT JOIN departments t2ON t1.department_id = t2.department_id;

右上图(右外连接):

select t1.name,t2.department_namefrom employees t1 RIGHT JOIN departments t2ON t1.department_id = t2.department_id;

左中图:

select t1.name,t2.department_namefrom employees t1 LEFT JOIN departments t2ON t1.department_id = t2.department_idWHERE t2.department_id IS NULL;

右中图:

select t1.name,t2.department_namefrom employees t1 RIGHT JOIN departments t2ON t1.department_id = t2.department_idWHERE t1.department_id IS NULL;

左下图(满外连接):

#方式一:左上图 UNION ALL 右中图select t1.name,t2.department_namefrom employees t1 LEFT JOIN departments t2ON t1.department_id = t2.department_idUNION ALL select t1.name,t2.department_namefrom employees t1 RIGHT JOIN departments t2ON t1.department_id = t2.department_idWHERE t1.department_id IS NULL;#方式二:左中图 UNION ALL 右上图select t1.name,t2.department_namefrom employees t1 LEFT JOIN departments t2ON t1.department_id = t2.department_idWHERE t2.department_id IS NULLUNION ALLselect t1.name,t2.department_namefrom employees t1 RIGHT JOIN departments t2ON t1.department_id = t2.department_id;

右下图:

#左中图 UNION ALL 右中图select t1.name,t2.department_namefrom employees t1 LEFT JOIN departments t2ON t1.department_id = t2.department_idWHERE t2.department_id IS NULLUNION ALLselect t1.name,t2.department_namefrom employees t1 RIGHT JOIN departments t2ON t1.department_id = t2.department_idWHERE t1.department_id IS NULL;

SQL语法新特性

自然连接

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

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

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

select t1.name,t2.department_namefrom employees t1 JOIN departments t2ON t1.department_id = t2.department_id;等价于select t1.name,t2.department_namefrom employees t1 JOIN departments t2USING(department_id);

“MySQL多表查询案例分析”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯