旗下导航:搜·么
当前位置:网站首页 > MySQL教程 > 正文

mysql的多表查询细致解说【MySQL教程】,多表查询

作者:搜教程发布时间:2019-12-01分类:MySQL教程浏览:38评论:0


导读:起首,为了轻易申明题目,建立两个表emp(雇员信息)和dept(雇员部门信息),其数据以下:在之前的文章中,我们分享了单表查询的要领,然则在现实运用中,我们要查的数据极可能...
起首,为了轻易申明题目,建立两个表emp(雇员信息)和dept(雇员部门信息),其数据以下:

在之前的文章中,我们分享了单表查询的要领,然则在现实运用中,我们要查的数据极可能不在统一个表中,而是来自于差别的表。多表查询假如不加任何条件,获得的效果称为笛卡尔积。 比方,查找雇员名、雇员工资以及部门地点的名字。

能够发明,效果是如许的,从第一个表中选出第一条纪录,和第二个表中的一切一切纪录举行组合,然后再从第一个表中掏出第二条纪录,和第二张表的一切纪录举行组合,如许的效果是没有现实意义的。我们须要的是emp.deptno = dept.deptno字段的纪录。

自衔接

自衔接是指在统一张表衔接查询

显现员工FORD的上级领导的名字

子查询

子查询是指嵌入在其他sql语句中的select语句,也叫嵌套查询。

单行子查询:子查询的查询效果只要一行

显现和SMITH统一部门的员工

多行子查询(in ,all, any):返回多条纪录的子查询

查询和10好部门的事情雷同的官员的名字、事情、工资、部门号,然则不包括10号本身的信息

显现工资比部门编号为30的一切员工的工资高的员工的姓名、工资和部门号

显现工资比部门编号为30的恣意员工的工资高的员工的姓名、工资和部门号

多列子查询:查询返回多个列数据的子查询语句

查询和SMITH的部门和岗亭完全雷同的雇员,不含SMITH本人

from子句中运用子查询

显现高于本身部门的平均工资的员工信息

查找每一个部门工资最高的人的ename, job, sal

显现每一个部门的信息(部门名、编号、地点)和职员数目

这里有两种要领能够运用,然则经考证,当数据异常多的时刻from子查询的效力是高于多表查询的。

删除表中的反复纪录

已知一个表tt中有反复的数据

建立一张空表tmp_tt,空表的构造与表tt的构造雷同;create table tmp_tt like tt;

将tt表举行distinct,将数据导入空表中;insert into tmp_tt select distinct * from tt;

删除原表ttdrop table tt;

将tmp_tt改名为ttalter table tmp_tt rename tt;

兼并查询

在现实运用中,为了兼并多个select的实行效果,能够运用union,union all鸠合操作符

1、union操作符用于获得两个效果的并集,并再自动去掉反复行 ,查找工资大于2500和职位Manger的人

2. union all 与union相似,然则不会自动去重
比方:与or相似

外键

外键定义主表和从表的关联,外键束缚主如果定义在从表上,主表必需是有主键或许唯一键。当定义外键后,请求外键列数据必需在主表列存在或许为NULL。
比方:建立一个主表class,从表stu

由上图,我们能够晓得主键不能为null,然则外键能够为null,同时不能存在外键有的数据而主表中不存在。

更多相干题目请接见ki4网:mysql视频教程

以上就是mysql的多表查询细致解说的细致内容,更多请关注ki4网别的相干文章!

标签:多表查询


欢迎 发表评论: