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..... 应用场景:要查询的结果来自于多个表,且多个表没有 ...
随机推荐
- Segment tree Beats
Segment tree Beats Segment tree Beats,吉司机线段树,主要是关于如何用线段树实现区间取min/max.我们先看一道例题: HDU5306 Gorgeous Sequ ...
- Mock接口数据 = mock服务 + iptable配置
一.mock接口数据应用场景: 1.测试接口A,A接口代码中调用其他服务的B接口,由于开发排期.测试环境不通等原因,依赖接口不可用 2.测试异常情况,依赖接口B返回的数据格式不对.返回None.超时等 ...
- python字符串学习总结
python字符串是不可变类型 所以没有添加和删除操作,更改元素,不会更改元素本身,可以用id(str) 测试,只有从新赋值新的对象才有效果.
- jmeter 线程数—请求数详解
一个性能测试请求负载是基于一个线程组完成的.一个测试计划必须有一个线程组.测试计划添加线程组非常简单.在测试计划右键弹出下拉菜单(添加-->Threads(Users)--->线程组)中选 ...
- 【focus-lei 】微服务
随笔分类 - 微服务 .net core使用NLog+Elasticsearch记录日志 摘要:在微服务或分布式系统中,如果将日志作为文件输出,查看系统日志将非常不便:如果将日志保存到数据库中,又不能 ...
- C#linq计算总条数并去重复的写法
一,在实际需求中我们会存在选出了一个集合,而这时我们需要通过集合的某几个字段来计算重复,和统计重复的数量,这时我们可以用到linq来筛选和去重复. 二,如下代码: using System; usin ...
- mysql语句之DDL
SQL分类: DDL(Data Definition Languages)语句:数据定义语言,这些语句定义了不同的数据段.数据库.表.列.索引等数据库对象的定义.常用的语句关键字主要包括create. ...
- 02.Windows2012R2安装360安全卫士失败及无法卸载问题
问题: Windows 2012 R2 安装360安全卫士失败及无法卸载,导致网络无法通信问题解决. 解决:1.进入 Windows2012R2 安全模式下:2.进行覆盖安装360安全卫士:3.覆盖安 ...
- mysql 导出表中数据为excel的xls格式文件
需求: 利用mysql客户端导出数据库中数据,以便进行分析,统计. 解决命令: 在windos命令行(linux同理)下,用如下命令即可: mysql -hlocalhost -uroot -ppas ...
- Flutter-TextField初始化值和選中取值
import 'package:flutter/material.dart'; class PersonalCenterInformationScreen extends StatefulWidget ...