MySQL 查询语句--------------进阶6:连接查询
#进阶6;连接查询
/*
含义:多个表格连接,当查询的字段来自于多个表时候,就会用到连接查询
我觉得这里类似于excel中的vlookup函数 笛卡尔乘积现象:表1有m行,表2有n行,结果有m*n行 如何发生:没有有效的连接条件
怎么解决:添加有效的连接条件
分类:
按照年代分类
sql92标准:仅仅支持内连接
sql99标准【推荐】:支持内连接+外连接(左外和右外)+交叉连接 按照功能分类:
内连接:等值连接,非等值连接,自连接 外连接:左外连接,右外连接,全外连接 交叉连接
*/
use girls;
select * from beauty;#12行
select * from boys; #4行
#出现笛卡尔乘积现象
select name,boyName from beauty,boys; #48行,这样是错的
#正确写法
select name,boyName from beauty,boys where beauty.boyfriend_id=boys.id; #一、sql92标准
#1.等值连接
/*
(1)多表的等值连接的结果为多表的交集
(2)n表连接,至少需要n-1个连接条件
(3)多表的顺序没有要求
(4)一般为表起别名
(5)可以搭配之前讲过的语法,例如order by,group by等
语法:
select 查询列表 from 表1 别名,表2,别名 【where 筛选】【group by 分组】【having 筛选条件】【order by排序】 */
#案例1:查询女神名和对应的男神名
select name,boyName from beauty,boys where beauty.boyfriend_id=boys.id; #案例2:查询员工名和对应的部门名
use myemployees;
select last_name,department_name from employees,departments where employees.department_id=departments.department_id; #2.为表取别名
/*
(1)提高语句的简洁度
(2)区分多个重名的字段 注意:如果为表起了别名,则查询的字段就不能使用原来的表名取限定
*/
# 查询员工名,工种号,工种名
select e.last_name,e.job_id,j.job_title from employees as e,jobs as j where e.job_id=j.job_id; #3.两个表的顺序是否可以调换(可以)
# 查询员工名,工种号,工种名
select e.last_name,e.job_id,j.job_title from jobs as j,employees as e where e.job_id=j.job_id; #4.可以做筛选吗
#案例1:查询有奖金的员工名、部门名
where e.commission_pct is not null #筛选条件
use myemployees;
select last_name,department_name, commission_pct from employees as e,departments as d where e.department_id=d.department_id and e.commission_pct is not null; #案例2:查询城市名中第二个字符为o, 对应的部门名和城市名
select department_name,city from departments as d,locations as l where d.location_id=l.location_id and l.city like "_o%"; #5.可以加分组? #案例1:查询每个城市的部门个数
select count(*) as "个数",city from departments as d,locations as l where d.location_id=l.location_id group by city; #案例2:查询有奖金的每个部门的部门名和部门领导编号,以及该部门的最低工资
select min(salary),department_name,e.manager_id from employees as e,departments as d where e.department_id=d.department_id and e.commission_pct is not null group by d.department_name,e.manager_id; #6.可以加排序 #7.可以实现三表连接吗?
# 案例:查询员工名、部门名和所在的城市
select last_name,department_name,city from employees as e,departments as d,locations as l where e.department_id=d.department_id and d.location_id=l.location_id; # 2.非等值连接
# 首先创建一个job_grades表
CREATE TABLE job_grades
(grade_level VARCHAR(3),
lowest_sal int,
highest_sal int); INSERT INTO job_grades
VALUES ('A', 1000, 2999); INSERT INTO job_grades
VALUES ('B', 3000, 5999); INSERT INTO job_grades
VALUES('C', 6000, 9999); INSERT INTO job_grades
VALUES('D', 10000, 14999); INSERT INTO job_grades
VALUES('E', 15000, 24999); INSERT INTO job_grades
VALUES('F', 25000, 40000);
# 查看job_grades表
use myemployees;
select * from job_grades; #案例1:查询员工的工资和工资级别;
select salary,grade_level from employees as e,job_grades as jg where salary between lowest_sal and highest_sal;
# 加筛选条件
select salary,grade_level from employees as e,job_grades as jg where salary between lowest_sal and highest_sal and jg.grade_level="A"; #3.自连接(没太明白,只知道在同一张表建立连接关系) #案例:查询 员工名和上级的名称
select employee_id,last_name,manager_id from employees;#错的 #案例:
已知表student 里面有id(学号),name,gradeID(年级编号)
已知表grade 里面有id(年级编号),name(年级名)
已知表result 里面有id,score,studentNo(学号)
要求查询姓名、年级名、成绩 select stu.name,gra.name,res.score from student as stu,grade as gra,result as res where stu.gradeID=gra.id and stu.id=res.studentNo; # 二、sql99标准【推荐】:支持内连接+外连接(左外和右外)+交叉连接
/*
语法:
select 查询列表 from 表1 别名【连接类型】
join 表2 别名 on 连接条件 【where 筛选条件】【group by 分组】【having 筛选条件】【order by排序】
分类【连接类型】:
内连接 innner
外连接:
左外 left 【outer】
右外 right 【outer】
全外 full 【outer】
交叉连接:cross
*/
1)内连接
/*
语法:
select 查询列表 from 表1 别名 inner
join 表2 别名 on 连接条件;
分类:等值连接,非等值连接,自连接
*/
#1.等值连接
#案例1:查询女神名和对应的男神名
use girls;
select name,boyName from beauty inner join boys on beauty.boyfriend_id=boys.id; # 在别名,调换顺序,筛选等与sql92的内连接一致
#案例1:查询有奖金的员工名、部门名
where e.commission_pct is not null #筛选条件
use myemployees;
select last_name,department_name, commission_pct from employees as e inner join departments as d on e.department_id=d.department_id where e.commission_pct is not null; #2.非等值连接
#案例1:查询员工的工资和工资级别;(inner可以省略)
select salary,grade_level from employees as e inner join job_grades as jg on salary between lowest_sal and highest_sal;
# 加筛选条件
select salary,grade_level from employees as e inner join job_grades as jg on salary between lowest_sal and highest_sal where jg.grade_level="A"; #3.自连接(没太明白,只知道在同一张表建立连接关系) #二、外连接
/*
应用场景:用于查询一个表中有,另外一个表中没有的记录
特点:
1.外连接的查询结果为主表中的所有记录
如果从表中有和他匹配的,则显示匹配的值
如果从表中没有和他匹配的,则显示null
外连接的查询结果 = 内连接的查询结果+主表中有而从表中没有的记录 2.左外连接:left join左边的是主表
右外连接:right join右边的是主表 3.左外和右外交换2个表的顺序,可以实现同样的效果
4.全外连接 = 内连接的结果 + 表1中有但是表2中没有的 + 表2中有但是表1中没有的
*/
use girls;
select * from beauty;
select * from boys;
引入:查询男朋友 不在男神表中的女神名字
# 我们先查下男朋友 在男神表中的女神名字
select name,boyName from beauty inner join boys on beauty.boyfriend_id=boys.id;
#左外连接
select name,boyName from beauty left join boys on beauty.boyfriend_id=boys.id; #右外连接
select name,boyName from boys right join beauty on beauty.boyfriend_id=boys.id;
#以上左外和右外结果一致 #查询没有男朋友的
select name,boyName from beauty left join boys on beauty.boyfriend_id=boys.id where boys.boyName is null; #案例1:查询哪个部门没有员工
use myemployees;
左外连接
select d.*,e.employee_id from departments as d left join employees as e on e.department_id=d.department_id where e.employee_id is null;
右外连接
select d.*, e.employee_id from employees as e right join departments as d on e.department_id=d.department_id where e.employee_id is null; #全外 full join
use girls; #交叉连接
cross join
也就是笛卡尔乘积
select name,boyName from beauty cross join boys; #sql92 PK sql99
内连接:说明:组合两个表中的记录,返回关联字段相符的记录,也就是返回两个表的交集(阴影)部分。

左连接:left join 是left outer join的简写,它的全称是左外连接,是外连接中的一种。
左(外)连接,左表(a_table)的记录将会全部表示出来,而右表(b_table)只会显示符合搜索条件的记录。右表记录不足的地方均为NULL。

右连接:right join是right outer join的简写,它的全称是右外连接,是外连接中的一种。
与左(外)连接相反,右(外)连接,左表(a_table)只会显示符合搜索条件的记录,而右表(b_table)的记录将会全部表示出来。左表记录不足的地方均为NULL。


MySQL差集MINUS运算符:其实是https://www.yiibai.com/mysql/minus.html
也就是第一列第二个结果
MySQL 查询语句--------------进阶6:连接查询的更多相关文章
- MySQL 进阶6: 连接查询 (多表连接) : 等值连接/非等值连接 /左右全连接/内连接
#进阶6: 连接查询 (多表连接) : 等值连接/非等值连接 /左右全连接/内连接 /* 含义: 当查询的字段来自于多个表时, 就会用到连接查询 一: sql 92标准 :等值连接 ,(#内连接) 1 ...
- MySQL 查询语句--------------进阶7:子查询
#进阶7:子查询 /* 含义: 出现在其他语句中的select语句,称为子查询或者内查询 外部的查询语句,称为主查询或外查询 分类: 按照子查询出现的位置: select后面:只支持标量子查询 fro ...
- MySQL之多表查询一 介绍 二 多表连接查询 三 符合条件连接查询 四 子查询 五 综合练习
MySQL之多表查询 阅读目录 一 介绍 二 多表连接查询 三 符合条件连接查询 四 子查询 五 综合练习 一 介绍 本节主题 多表连接查询 复合条件连接查询 子查询 首先说一下,我们写项目一般都会建 ...
- MySQL数据库查询操作进阶——多表查询
多表查询 在大部分情况下,我们用到的表都是彼此相关联的,所以我们会有相当大的需求用到跨表的查询,这个时候我们就需要将相关联的表连起来做多表查询. 多表查询分为连表查询和子查询,连表查询即将相关联的表连 ...
- MySQL数据库实验三:连接查询
实验三 连接查询 实验名称:连接查询(2课时) 一.实验目的 理解JOIN语句的操作和基本使用方法,掌握内连接.外连接.自身连接的概念和使用. 二.实验环境 是MS SQL SERVER 200 ...
- MySQL全面瓦解12:连接查询的原理和应用
概述 MySQL最强大的功能之一就是能在数据检索的执行中连接(join)表.大部分的单表数据查询并不能满足我们的需求,这时候我们就需要连接一个或者多个表,并通过一些条件过滤筛选出我们需要的数据. 了解 ...
- mysql学习之路_连接查询
回顾 列属性:主键,自增长,唯一键. 关系:一对一,一对多,多对多 三层范式: 1NF:字段设计必须符合原子性 2NF:不存在部分依赖(没有复合主键) 3NF:不存在传递依赖(实体单独成表) 逆规范化 ...
- 010.简单查询、分组统计查询、多表连接查询(sql实例)
-------------------------------------day3------------ --添加多行数据:------INSERT [INTO] 表名 [(列的列表)] --SEL ...
- MySQL 查询语句--------------进阶9:联合查询
#进阶9:联合查询 /* union 联合 合并:将多条查询语句的结果合并成一个结果 语法: 查询语句1 union 查询语句2 union..... 应用场景:要查询的结果来自于多个表,且多个表没有 ...
随机推荐
- Kubeadm安装Kubernetes 1.15.1
一.实验环境准备 服务器虚拟机准备 IP CPU 内存 hostname 192.168.198.200 >=2c >=2G master 192.168.198.201 >=2c ...
- 2019牛客暑期多校训练营(第三场) - J - LRU management - 模拟
https://ac.nowcoder.com/acm/contest/883/J 根据这个数据结构的特点,也就是计算机组成原理里面学过的cache的LRU管理算法,每次访问都会在cache中查询一页 ...
- java 快速开发平台 有代码生成器 springmvc SSM后台框架源码
. 权限管理:点开二级菜单进入三级菜单显示 角色(基础权限)和按钮权限 角色(基础权限): 分角色组和角色,独立分配菜单权限和增删改查权限. 按钮权限: 给角色分配按钮权限.2 ...
- 用jquery制作的简单轮播图
我也是进入H5前端的小菜鸟一枚,最近才进入jquery的学习,所以打算对自己的学习进行记录. 今天分享的是一个简单的轮播图,这个轮播图的特效很简单,能够进行图片的轮播以及点击相应图片,图片能够跳转到相 ...
- 记录面试一位三年经验Web前端开发者的过程
今天是2019年6月5日,后天就是端午节了,提前祝端午节快乐! 好了,开始这次面试过程的正题部分. 当我从人事手中接下这份三年哥(暂拟名称)的简历的时候,看到三年工作经验,心想 这应该是个大佬了 挺厉 ...
- C++内存的分区
内存一共4个区 1.任何在函数内部声明的非static变量,其变量地址本身在栈区.栈是向低地址扩展的数据结构,即栈顶的地址和栈的最大容量是系统预先规定好的.2.任何全局变量或者静态局部变量,其变量地址 ...
- Java基础学习(3)
Java基础学习(三) Java异常 Throwable类:所有异常的祖先类 Error:虚拟机异常.内存错误.没法处理 Exception:编码.环境.用户操作输入出现问题 非检查异常(自动捕获): ...
- python面向对象--类的内置函数
#isinstance(obj,cls)判断obj是否是类cls的实例 #issubclass(cls,cls1)判断cls是否是cls1的子类或派生类 class Foo: pass class B ...
- cat 合并文件或查看文件内容
1.命令功能 cat 合并文件或者查看文件内容. 2.语法格式 cat option file 参数说明 参数 参数说明 -n 打印文本,并显示每行行号并且空白行也同样包括 -b 与-n用法 ...
- python3-sorted
排序也是在程序中经常用到的算法.无论使用冒泡排序还是快速排序,排序的核心是比较两个元素的大小.如果是数字,我们可以直接比较,但如果是字符串或者两个dict呢?直接比较数学上的大小是没有意义的,因此,比 ...