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

MySql中的连接查询问题

MySql连接查询MySql查询MySql连接查询问题 2023-03-20 09:03:30 204人浏览 薄情痞子
摘要

目录连接查询连接查询的分类笛卡尔积现象内连接之等值连接内连接之自连接内连接之非等值连接外连接内连接和外连接的特点多表连接总结连接查询 当进行多表连接查询时 需要指定字段所属的表 , 可以提高查询效率 , 如果不指定字段所

连接查询

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

  • 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.dname
	from
		emp e, dept d
	where
		e.deptno = d.deptno;
		
	--sql99优点:表连接的条件是独立的,连接之后,如果还需要进一步筛选,再往后继续添加where		
	select 
		e.ename,d.dname
	from
		emp e
	--inner可以省略(带着inner可读性更好)
	(inner) join
		dept d
	on
		e.deptno = d.deptno;

内连接之自连接

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

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

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

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

--SQL92
select e.ename, m.ename from emp e, emp m where e.mgr=m.empno;

--SQL99
select 
	a.ename as '员工名', b.ename as '领导名'
from
	emp e
join
	emp m
on
	e.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.grade
from
	emp e
(inner) join
	salgrade s
on
	e.sal between s.losal and s.hisal; 

外连接

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

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

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

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

--左连接
select 
	a.ename as '员工名', b.ename as '领导名'
from
	emp a
left (outer) join
	emp b
on
	a.mgr = b.empno; 

--右连接
select 
	a.ename as '员工名', b.ename as '领导名'
from
	emp b
right (outer) join
	emp a
on
	a.mgr = b.empno;

内连接和外连接的特点

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

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

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

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

select 
	e.ename,d.dname
from
	emp e
join
	dept d
on
	e.deptno = d.deptno; 

MySql中的连接查询问题

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

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


--外连接(左外连接)
select 
	e.ename,d.dname
from
	dept d 
--outer是可以省略的,带着可读性强
left (outer) join 
	emp e
on
	e.deptno = d.deptno;

MySql中的连接查询问题

多表连接

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

--表示一: a 和 b 进行内连接 , a 和 c 进行内连接 , a 和 d 进行右外连接(推荐)

--表示二: a 和 b 的内连接结果去内连接 c 的结果再去右外连接 d
select 
	...
from
	a
join
	b
on
	a和b的连接条件
join
	c
on
	a和c的连接条件
right join
	d
on
	a和d的连接条件

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

	select 
		e.ename,e.sal,d.dname,s.grade
	from
		emp e
	join
		dept d
	on 
		e.deptno = d.deptno
	join
		salgrade s
	on
		e.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.ename
	from
		emp e
	join
		dept d
	on 
		e.deptno = d.deptno
	join
		salgrade s
	on
		e.sal between s.losal and s.hisal
	left join
		emp l
	on
		e.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 |
	+--------+---------+------------+-------+-------+

总结

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

您可能感兴趣的文档:

--结束END--

本文标题: MySql中的连接查询问题

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

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

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

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

下载Word文档
猜你喜欢
  • MySql中的连接查询问题
    目录连接查询连接查询的分类笛卡尔积现象内连接之等值连接内连接之自连接内连接之非等值连接外连接内连接和外连接的特点多表连接总结连接查询 当进行多表连接查询时 需要指定字段所属的表 , 可以提高查询效率 , 如果不指定字段所...
    99+
    2023-03-20
    MySql连接查询 MySql查询 MySql连接查询问题
  • MySQL中连接查询和子查询的问题
    目录多表连接的基本语法交叉连接和笛卡尔积现象交叉连接笛卡尔积现象内连接外连接左外连接右外连接全外连接子查询多表连接的基本语法 多表连接,就是将几张表拼接为一张表,然后进行查询 s...
    99+
    2022-11-12
  • MySql中的连接查询问题怎么解决
    本文小编为大家详细介绍“MySql中的连接查询问题怎么解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“MySql中的连接查询问题怎么解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。连接查询当进行多表连接查询...
    99+
    2023-07-05
  • MySQL中的连接查询(等值连接)
    目录1. 笛卡尔乘积2. 分类(1)按年代分类(2)按功能分类3. 等值连接4. 总结1. 笛卡尔乘积 表1有m行数据,表2有n行数据,查询结果有m*n行数据。 2. 分类 (1)按年代分类 sql92标准:仅支持内连接...
    99+
    2022-07-20
    MySQL连接查询 MySQL等值连接 MySQL中的查询
  • mysql连接查询
    11.5连接查询(列连接) 问题:学生表有十条数据,成绩表有十条数据。 连接之后有多少条数据(笛卡尔积):10*10=100   连续查询会产生笛卡尔积;假设集合A = {a,b},集合B = {c,d} 两个集合的笛卡尔积{(a,c),...
    99+
    2020-01-06
    mysql连接查询
  • Mysql Join-连接查询(中)
    Mysql Join-连接查询(中) 认识 就我平时的数据接触来看, 连接查询也没有很复杂,不够是非常需要耐心和逻辑的, 一点点将数据查出来, 拼接等. 没有什么技巧, 多练习就会了. 无非就是表之间根据共同key来连接, 查询时结合uni...
    99+
    2016-09-20
    Mysql Join-连接查询(中)
  • 连接查询(多表查询)——MySQL
    连接查询(多表查询) 又称多表查询,当查询的字段涉及多个表的时候,就要用到连接查询 分类: 为表起别名: 提高语句的简洁度区分多个重名字段注意:如果为表起了别名,则查询的字段就不能使用原来的别名去限定 内连接 查询A、B 交集部分数据 语...
    99+
    2023-08-18
    数据库 mysql 多表查询
  • MYSQL自连接查询
    MYSQL自连接查询 概念:左表和右表是同一个表,根据连接查询条件查询两个表中的数据. 说明: ​ (1)自连接查询必须对表起别名; ​ 2) 自连接的使用方法和内连接,左连接,右连接完全相同,只不过连接的左表和右表是同一张表. 案例 CR...
    99+
    2023-08-20
    mysql 数据库 sql
  • mysql 连接查询(俗称连表查询)内连接、外连接、自然连接
    连接查询的分类 本文讨论中用到的测试数据``create table student(id int primary key auto_increment,name varchar(10));ins...
    99+
    2022-10-18
  • MySQL之连接查询和子查询
    多表连接的基本语法 多表连接,就是将几张表拼接为一张表,然后进行查询 select 字段1, 字段2, ... from 表1 {inner|lift|right} join 表2 on 连接条件; 有如下两张表:部门表和员工...
    99+
    2015-01-24
    MySQL之连接查询和子查询
  • mysql连接查询详解
    目录1.连接查询2、连接类型内连接定义:语法1: 语法2: 3个表连接显示指定列左连接定义:语法:右连接  定义:语法:自关联定义 ...
    99+
    2022-11-13
  • mysql连接查询左连接,右连接,内连接的示例
    小编给大家分享一下mysql连接查询左连接,右连接,内连接的示例,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一、mysql常用连接INNER JOIN(内连接,或等值连接):获取两个表中...
    99+
    2022-10-18
  • MySQL数据查询之连接查询的案例
    小编给大家分享一下MySQL数据查询之连接查询的案例,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!连接关系是关系数据库模型的主要...
    99+
    2022-10-18
  • MySQL三个表的连接查询
    MySQL三个表的连接查询 select first_name,title,salary,s.to_date from employees e  inner join titles t on e.emp_no = t.em...
    99+
    2016-02-15
    MySQL三个表的连接查询
  • MySQL:测试与查询的连接?
    将任何预定义函数与选择查询一起使用,或者您可以使用选择查询打印一些单词,以测试与查询的连接。语法如下。SELECT yourValue;预定义函数的选择查询如下。语法如下。SELECT anyPredefinedFunctionName()...
    99+
    2023-10-22
  • Mysql中的嵌套子查询问题
    目录Mysql嵌套子查询在WHERE子句中使用子查询单行单列子查询单行多列子查询。多行单列子查询FROM子查询:总结:select子查询用子查询用子查询Mysql嵌...
    99+
    2022-11-13
  • Mysql数据库连接查询
        Mysql数据库连接查询连接是关系数据库模型的主要特点。连接查询是关系数据库中最主要的查询,主要包括内连接、外连接等。通过连接运算可以实现多个表查询。当查询数...
    99+
    2022-10-18
  • MYSQL数据库--连接查询
    连接查询 连接是把不同表的记录连到一起的最普遍的方法。一种错误的观念认为由于MySQL的简单性和源代码开放性,使它不擅长连接。这种观念是错误的。MySQL从一开始就能够很好地支持连接,现在还以支持标准的S...
    99+
    2022-10-18
  • 什么是MySQL 连接查询
    什么是MySQL 连接查询?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。          ...
    99+
    2022-10-18
  • MySQL连接查询是什么
    这篇文章主要为大家展示了“MySQL连接查询是什么”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“MySQL连接查询是什么”这篇文章吧。内连接内连接INNERJOIN是最常用的连接操作。从数学的角...
    99+
    2023-06-29
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作