广告
返回顶部
首页 > 资讯 > 数据库 >MySql中的连接查询问题怎么解决
  • 548
分享到

MySql中的连接查询问题怎么解决

2023-07-05 14:07:03 548人浏览 独家记忆
摘要

本文小编为大家详细介绍“MySql中的连接查询问题怎么解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“Mysql中的连接查询问题怎么解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。连接查询当进行多表连接查询

本文小编为大家详细介绍“MySql中的连接查询问题怎么解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“Mysql中的连接查询问题怎么解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

    连接查询

    当进行多表连接查询时 需要指定字段所属的表 , 可以提高查询效率 , 如果不指定字段所属的表 , 数据库会从每个表中都找一下该字段

    • e . 字段名 : 表示取 emp 表的某个字段

    • emp as e : 表的别名机制 , 可以省略 as 直接写成 emp e

    • 连接查询:也可以叫跨表查询,需要关联多张表联合起来查询数据

    • emp表和dept表联合起来查询数据,从emp表中取员工名字,从dept表中取部门名字

    注意: 做连接查询的时候一定要写上关联条件 避免笛卡尔积现象

    连接查询的分类

    根据语法的年代分类

    SQL92:1992年的时候出现的语法

    • sql92的缺点:结构不清晰,表的连接条件,和后期进一步筛选的条件,都放到了where后面

    SQL99:1999年的时候出现的语法(重点学习)

    • sql99优点:表的连接条件和查询条件分离,连接之后如果还需要进一步筛选,再往后继续添加where , 多个表进行连接的时候更清晰

    根据表连接的方式分类

    内连接:等值连接 , 非等值连接 , 自连接 , inner 可以省略 一般不加

    • 表 A inner join 表 B on 关联条件

    外连接:左外连接(左连接), 右外连接(右连接), outer 可以省略一般不加

    • 表 A left outer join 表 B on 关联条件

    • 表 B right outer join 表 A on 关联条件

    • 左连接以左面的表为准和右边的表比较,和左表相等的不相等都会显示出来,而右表符合条件的显示,不符合条件的不显示 (右连接恰恰相反)

    • 左连接能完成的功能右连接一定可以完成

    全连接 , 连接的两张表都是主表 , 都能查询出来

    笛卡尔积现象

    当两张表进行连接查询,没有指定连接条件的时候,最终查询结果条数是两张表条数的乘积,这种现象被称为:笛卡尔积现象(笛卡尔发现的,这是一个数学现象)

    避免笛卡尔积现象:连接多个表时加连接条件,将满足这个条件的记录被筛选出来

    • 匹配的过程中匹配的次数没有减少 , 但是最终查询的结果条数是变少了 , 因为根据连接条件进行了筛选

    • 通过笛卡尔积现象得出,表的连接次数越多效率越低,尽量避免表的连接次数

    内连接之等值连接

    因为条件是等量关系,所以被称为等值连接(连接条件相等的数据)

    查询每个员工所在部门名称,显示员工名和部门

    emp e和dept d表进行连接 , 连接条件是:e.deptno = d.deptno

    --sql92的缺点:结构不清晰,表的连接条件,和后期进一步筛选的条件,都放到了where后面select e.ename,d.dnamefromemp e, dept dwheree.deptno = d.deptno;--sql99优点:表连接的条件是独立的,连接之后,如果还需要进一步筛选,再往后继续添加whereselect e.ename,d.dnamefromemp e--inner可以省略(带着inner可读性更好)(inner) joindept done.deptno = d.deptno;

    内连接之自连接

    因为只有一张表连接,具体的查询方法是把一张表看作两张表自己连接自己 , 所以成为自连接

    查询员工的上级领导,要求显示员工名和对应的领导名

    一张表看成两张表 , emp e 代表了员工表,emp m 也代表了领导表

    连接条件: e.mgr = m.empno 员工的领导编号 = 领导的员工编号

    --SQL92select e.ename, m.ename from emp e, emp m where e.mgr=m.empno;--SQL99select a.ename as '员工名', b.ename as '领导名'fromemp ejoinemp mone.mgr = m.empno;

    内连接之非等值连接

    因为连接条件不是一个等量关系,所以称为非等值连接

    显示薪水大于 2000 的员工信息,并显示所属的部门名称

    --采用 SQL92 语法select e.ename, e.sal, d.dname from emp e, dept d where e.deptno=d.deptno and e.sal > 2000;--采用 SQL99 语法select e.ename, e.sal, d.dname from emp e (inner) join dept d on e.deptno=d.deptno where e.sal>2000;

    找出每个员工的薪资等级,要求显示员工名、薪资、薪资等级

    select e.ename, e.sal, s.gradefromemp e(inner) joinsalgrade sone.sal between s.losal and s.hisal;

    外连接

    外连接: 在外连接当中,两张表连接产生了主次关系 , 主要查询的是主表的数据 , 捎带着关联查询次表 , 即如果对方没有记录和我主表匹配 , 那么默认对方是null , outer关键字可以省略

    • 右外连接: 带有 right 的是右外连接,表示将join关键字右边的这张表看成主表,主要是为了将这张表的数据全部查询出来,捎带着关联查询左边的表

    • 左外连接: 带有 lef t的是左外连接 , 表示将join关键字左边的这张表看成主表,主要是为了将这张表的数据全部查询出来,捎带着关联查询右边的表

    **注意: 任何一个右连接都有左连接的写法 , 任何一个左连接都有右连接的写法 **

    查询每个员工的上级领导,要求显示所有员工的名字和领导名 , 如果某个员工没有领导 , 那么该员工也必须显示出来

    --左连接select a.ename as '员工名', b.ename as '领导名'fromemp aleft (outer) joinemp bona.mgr = b.empno; --右连接select a.ename as '员工名', b.ename as '领导名'fromemp bright (outer) joinemp aona.mgr = b.empno;

    内连接和外连接的特点

    内连接:A表和B表连接,A和B两张表没有主次关系是平等的 , 查询时只是将能够匹配上连接条件的数据查询出来 , 即如果没有匹配的就查询不出来 , inner关键字可以省略

    外连接: 在外连接当中,两张表连接产生了主次关系 , 主要查询的是主表的数据 , 捎带着关联查询次表 , 即如果对方没有记录和我主表匹配 , 那么默认对方是null , outer关键字可以省略

    注意: 区分内外连接的办法是通过 right 和 left 关键字 , 不是通过 inner 和 outer 因为它们都可以省略 , 并且外连接的查询结果条数一定是大于等于内连接的查询结果条数

    显示员工信息,并显示所属的部门名称

    select e.ename,d.dnamefromemp ejoindept done.deptno = d.deptno;

    MySql中的连接查询问题怎么解决

    显示员工信息,并显示所属的部门名称,如果某一个部门没有员工,那么该部门也必须显示出来

    --外连接(右外连接)select e.ename,d.dnamefromemp e --outer是可以省略的,带着可读性强--right代表什么:表示将join关键字右边的这张表看成主表,主要是为了将这张表的数据全部查询出来,捎带着关联查询左边的表right (outer) join dept done.deptno = d.deptno;--外连接(左外连接)select e.ename,d.dnamefromdept d --outer是可以省略的,带着可读性强left (outer) join emp eone.deptno = d.deptno;

    MySql中的连接查询问题怎么解决

    多表连接

    一条SQL中内连接和外连接可以混合 , 都可以出现

    --表示一: a 和 b 进行内连接 , a 和 c 进行内连接 , a 和 d 进行右外连接(推荐)--表示二: a 和 b 的内连接结果去内连接 c 的结果再去右外连接 dselect ...fromajoinbona和b的连接条件joincona和c的连接条件right joindona和d的连接条件

    找出每个员工的部门名称以及工资等级,要求显示员工名、部门名、薪资、薪资等级

    select e.ename,e.sal,d.dname,s.gradefromemp ejoindept don e.deptno = d.deptnojoinsalgrade sone.sal between s.losal and s.hisal;

    查询结果

    +--------+---------+------------+-------+| ename  | sal     | dname      | grade |+--------+---------+------------+-------+| SMITH  |  800.00 | RESEARCH   |     1 || ALLEN  | 1600.00 | SALES      |     3 || WARD   | 1250.00 | SALES      |     2 || JONES  | 2975.00 | RESEARCH   |     4 || MARTIN | 1250.00 | SALES      |     2 || BLAKE  | 2850.00 | SALES      |     4 || CLARK  | 2450.00 | ACCOUNTING |     4 || SCOTT  | 3000.00 | RESEARCH   |     4 || KING   | 5000.00 | ACCOUNTING |     5 || TURNER | 1500.00 | SALES      |     3 || ADAMS  | 1100.00 | RESEARCH   |     1 || JAMES  |  950.00 | SALES      |     1 || FORD   | 3000.00 | RESEARCH   |     4 || MILLER | 1300.00 | ACCOUNTING |     2 |+--------+---------+------------+-------+

    找出每个员工的部门名称以及工资等级,还有上级领导,要求显示员工名、领导名、部门名、薪资、薪资等级

    select e.ename,e.sal,d.dname,s.grade,l.enamefromemp ejoindept don e.deptno = d.deptnojoinsalgrade sone.sal between s.losal and s.hisalleft joinemp lone.mgr = l.empno;

    查询结果

    +--------+---------+------------+-------+-------+| ename  | sal     | dname      | grade | ename |+--------+---------+------------+-------+-------+| SMITH  |  800.00 | RESEARCH   |     1 | FORD  || ALLEN  | 1600.00 | SALES      |     3 | BLAKE || WARD   | 1250.00 | SALES      |     2 | BLAKE || JONES  | 2975.00 | RESEARCH   |     4 | KING  || MARTIN | 1250.00 | SALES      |     2 | BLAKE || BLAKE  | 2850.00 | SALES      |     4 | KING  || CLARK  | 2450.00 | ACCOUNTING |     4 | KING  || SCOTT  | 3000.00 | RESEARCH   |     4 | JONES || KING   | 5000.00 | ACCOUNTING |     5 | NULL  || TURNER | 1500.00 | SALES      |     3 | BLAKE || ADAMS  | 1100.00 | RESEARCH   |     1 | SCOTT || JAMES  |  950.00 | SALES      |     1 | BLAKE || FORD   | 3000.00 | RESEARCH   |     4 | JONES || MILLER | 1300.00 | ACCOUNTING |     2 | CLARK |+--------+---------+------------+-------+-------+

    读到这里,这篇“mysql中的连接查询问题怎么解决”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网数据库频道。

    您可能感兴趣的文档:

    --结束END--

    本文标题: MySql中的连接查询问题怎么解决

    本文链接: https://www.lsjlt.com/news/352126.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • MySql中的连接查询问题怎么解决
      本文小编为大家详细介绍“MySql中的连接查询问题怎么解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“MySql中的连接查询问题怎么解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。连接查询当进行多表连接查询...
      99+
      2023-07-05
    • MySql中的连接查询问题
      目录连接查询连接查询的分类笛卡尔积现象内连接之等值连接内连接之自连接内连接之非等值连接外连接内连接和外连接的特点多表连接总结连接查询 当进行多表连接查询时 需要指定字段所属的表 , 可以提高查询效率 , 如果不指定字段所...
      99+
      2023-03-20
      MySql连接查询 MySql查询 MySql连接查询问题
    • MySQL中连接查询和子查询的问题
      目录多表连接的基本语法交叉连接和笛卡尔积现象交叉连接笛卡尔积现象内连接外连接左外连接右外连接全外连接子查询多表连接的基本语法 多表连接,就是将几张表拼接为一张表,然后进行查询 s...
      99+
      2022-11-12
    • 怎么解决mysql 查询中文乱码问题
      小编给大家分享一下怎么解决mysql 查询中文乱码问题,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧! mysql查询中文乱码的解决办法:1、在安装目录找到my....
      99+
      2022-10-19
    • 怎么解决mysql连接过慢的问题
      这篇文章主要讲解了“怎么解决mysql连接过慢的问题”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么解决mysql连接过慢的问题”吧! 3种解决方法(前...
      99+
      2022-10-18
    • MybatisPlus多表连接查询的问题及解决方案
      目录一、序言(一)背景内容(二)场景说明(三)前期准备二、一对一查询(一)查询单条记录(二)查询多条记录三、一对多查询(二)查询多条记录(三)查询多条记录(分页)四、多对多查询(一)...
      99+
      2022-11-13
    • Mybatisplus中的like查询问题怎么解决
      这篇“Mybatisplus中的like查询问题怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Mybatisplus...
      99+
      2023-07-02
    • MySQL慢查询优化解决问题
      目录1.  MySQL慢查询介绍2.发现问题(主动/被动)3.找到原因-对症下药1.  MySQL慢查询介绍   MySQL的慢查询日志是MySQL提供...
      99+
      2022-11-13
    • mysql之跨库关联查询问题怎么解决
      这篇文章主要介绍了mysql之跨库关联查询问题怎么解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇mysql之跨库关联查询问题怎么解决文章都会有所收获,下面我们一起来看看吧。1、解决方案mysql是不支持跨库...
      99+
      2023-07-05
    • 解决mysql连接超时和mysql连接错误的问题
      目录mysql连接超时和mysql连接错误连接MySQL错误create connection SQLException, url: jdbc:mysql://localhost:3306/*****解决方法mysql连...
      99+
      2022-07-11
      mysql连接超时 mysql连接错误
    • MySQL中的连接查询(等值连接)
      目录1. 笛卡尔乘积2. 分类(1)按年代分类(2)按功能分类3. 等值连接4. 总结1. 笛卡尔乘积 表1有m行数据,表2有n行数据,查询结果有m*n行数据。 2. 分类 (1)按年代分类 sql92标准:仅支持内连接...
      99+
      2022-07-20
      MySQL连接查询 MySQL等值连接 MySQL中的查询
    • Navicat连接不上MySQL的问题解决
      目录一、查看端口3306是否一样二、查看服务是否启动mysql密码忘记怎么办?总结解决Navicat连接不上Mysql的方法 一、查看端口3306是否一样 1、先登录上mysql,可以直接登录,或者cmd,从命令行那里进...
      99+
      2023-02-17
      navicat连接不上mysql navicat连接mysql报错 navicat连接不上数据库
    • 解决Qt6连接MySQL的驱动问题
      目录 1. 引出问题2. 分析问题3. 解决问题3.1 获取编译所需材料3.1.1准备生成Mysql驱动文件的工程3.1.2 准备Mysql相关的头、库文件 3.2 开始进行编译3.3 复制文件(重要)3.4 测试连接 4...
      99+
      2023-08-19
      mysql 数据库 qt c++
    • 怎么解决远程连接mysql错误1130的问题
      本篇内容介绍了“怎么解决远程连接mysql错误1130的问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!...
      99+
      2022-10-18
    • 超出MySQL最大连接数的问题怎么解决
      今天小编给大家分享的是超出MySQL最大连接数的问题怎么解决,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。超出MySQL最大连接数问题如果遇到MySQ连接数超出最大限制了,不要慌,往...
      99+
      2023-07-06
    • 怎么解决Navicat for Mysql连接报错1251的问题
      这篇文章主要介绍怎么解决Navicat for Mysql连接报错1251的问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!打开Command Line Client   看清楚不是cmd,是在...
      99+
      2023-06-15
    • mysql中查询字段为null的数据navicat问题怎么解决
      这篇“mysql中查询字段为null的数据navicat问题怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“mysql...
      99+
      2023-07-04
    • 怎么解决MySQL数据库出现慢查询问题
      这篇文章主要讲解了“怎么解决MySQL数据库出现慢查询问题”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么解决MySQL数据库出现慢查询问题”吧!1、My...
      99+
      2022-10-18
    • mysql left join查询慢时间长问题怎么解决
      本篇内容主要讲解“mysql left join查询慢时间长问题怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql ...
      99+
      2022-10-19
    • LINQ查询操作的问题怎么解决
      这篇文章主要介绍“LINQ查询操作的问题怎么解决”,在日常操作中,相信很多人在LINQ查询操作的问题怎么解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”LINQ查询操作的问题怎么解决”的疑惑有所帮助!接下来...
      99+
      2023-06-17
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作