SQL三表连接查询与集合的并、交、差运算查询
- use db_sqlserver2
- select 姓名, 工资, 面积, 金额, (工资+金额/1000) as 实发工资 from 职工,仓库, 订购单
- where 职工.职工号=订购单.职工号 and 职工.仓库号=仓库.仓库号

2:
- select 姓名,工资,金额 from 职工,订购单 where 姓名 like '%平%' and 职工.职工号 = 订购单.职工号 order by 工资 desc
3:
- select 姓名,工资,金额 from 职工,订购单 where 姓名 like '%平%' and 职工.职工号 = 订购单.职工号 order by 工资 desc, 金额 desc

4:
- select 姓名, 工资, 城市, (select AVG(工资) from 职工) as 平均工资 , (工资-(select AVG(工资) from 职工)) as 与平均工资之差
- from 职工, 仓库 where 仓库.仓库号=职工.仓库号

5:带保存功能的多表连接查询
在SQL语句中,利用into语句可以把查询到的结果保存成一张新表,然后再对新表进行数据信息查询。
- select 仓库.仓库号, 城市, 面积, 姓名, 工资, 金额 into 多表连接产生的新表 from 仓库, 职工, 订购单
- where 仓库.仓库号=职工.仓库号 and 职工.职工号=订购单.职工号
- select * from 多表连接产生的新表

//查看不同仓库中的所有职工的仓库号、平均销售金额、最大销售金额、最小销售金额、最大销售金额与最小销售金额之差的信息
- select 仓库号, AVG(金额) as 平均销售金额, MAX(金额) as 最大销售金额, MIN(金额) as 最小销售金额,
- (MAX(金额) - MIN(金额)) as 最大金额与最小金额之差 from 多表连接产生的新表 group by 仓库号;

可以把分组查询结果再生成一张新表
- select 仓库号, AVG(金额) as 平均销售金额, MAX(金额) as 最大销售金额, MIN(金额) as 最小销售金额,
- (MAX(金额) - MIN(金额)) as 最大金额与最小金额之差 into 分组查询产生的新表
- from 多表连接产生的新表 group by 仓库号;
- select * from 分组查询产生的新表
6: 内连接查询(inner join)
使用比较运算符对表之间的某些数据进行比较,并列出这些表中与连接条件相匹配的数据行。
- select 姓名, 城市 from 仓库 inner join 职工 on 职工.仓库号=仓库.仓库号
多表的内连接查询
- select 城市,面积, 姓名, 工资, 金额 from 仓库
- inner join 职工 on 职工.仓库号=仓库.仓库号
- inner join 订购单 on 职工.职工号=订购单.职工号
- and 工资>1800 and 面积<1000 and 金额 != 16600
7:左连接查询(left join)
除满足连接条件的记录显示外,第一张表中不满足条件的记录也显示在结果集中。
- select 姓名, 城市 from 仓库
- left join 职工 on 职工.仓库号=仓库.仓库号 and 城市 is not null and 姓名 like '%王%'

- select 城市, 面积, 姓名, 工资, 金额 from 仓库
- left join 职工 on 职工.仓库号 = 仓库.仓库号
- left join 订购单 on 职工.职工号=订购单.职工号
- and 工资>1800 and 面积<1000 and 金额!=16600

在第一个left join左连接中,第一张表是仓库表,第二张表是职工表,在第二个left join左连接中,第一张表是职工表,第二张表是订购单表
8:右连接查询
除满足连接条件的记录显示外,第二张表中不满足条件的记录也显示在查询结果集中
- select 姓名, 城市 from 仓库
- right join 职工 on 职工.仓库号=仓库.仓库号 where 城市 is not null and 姓名 like '%王%'

- select 城市, 面积, 姓名, 工资, 金额 from 仓库
- right join 职工 on 职工.仓库号=仓库.仓库号
- right join 订购单 on 职工.职工号=订购单.职工号
- and 工资>1500 and 面积<1000 and 金额!=16600

- select 城市, 面积, 姓名, 工资, 金额 from 仓库
- right join 职工 on 职工.仓库号=仓库.仓库号
- right join 订购单 on 职工.职工号=订购单.职工号
- <span style="color:#ff0000;">where</span> 工资>1500 and 面积<1000 and 金额!=16600
把and关键字换为where关键字后的效果图,会发现那些无用的数据没有了

9:全连接查询
除满足连接条件的记录显示外,两张表中的不能满足条件的记录也显示在查询结果集中
- select 姓名,城市 from 仓库 full join 职工 on 职工.仓库号=仓库.仓库号 and 城市 is not null and
- 姓名 like '%王%';

集合的交、并、差运算查询
为了进行并、交、差运算,要求运算的两个查询结果具有相同的字段个数,并且对应的字段的值要出自同一个值域,即具有相同的数据类型和取值范围
10:并运算(union)
主要将两个或者更多个查询的结果组合为单个结果集,该结果集包含联合查询中的全部查询的全部行
- select 仓库号 from 仓库 where 城市='北京'
- union
- select 仓库号 from 职工 where 工资>2000
- select 仓库号 from 仓库 where 城市='北京'
- union
- select 仓库号 from 职工 where 工资>2000
- select distinct 仓库.仓库号 from 仓库, 职工 where 仓库.仓库号=职工.仓库号 and (城市='北京' or 工资>2000)
使用union all 保留重复行
- select 仓库号 from 仓库 where 城市='北京'
- union all
- select 仓库号 from 职工 where 工资>2000

11:交运算(intersect)
可以将两个select语句的查询结果通过交运算合并成一个查询结果
- select 仓库号 from 仓库 where 城市='北京'
- intersect
- select 仓库号 from 职工 where 工资>2000
- select distinct 仓库.仓库号 from 仓库, 职工 where 城市='北京' and 仓库.仓库号=职工.仓库号 and 工资>2000

12:差运算(except)
可以计算两个select查询结果之间的数据差,即返回在一个查询结果中存在,但在另一个查询结果中不存在的所有行。
- select 仓库号 from 仓库 where 城市='北京'
- except
- select 仓库号 from 职工 where 工资>2900
- select 仓库号 from 仓库 where 城市='北京' and 仓库号 not in(select 仓库号 from 职工 where 工资>2900)

SQL三表连接查询与集合的并、交、差运算查询的更多相关文章
- SQL表连接查询(inner join、full join、left join、right join)
SQL表连接查询(inner join.full join.left join.right join) 前提条件:假设有两个表,一个是学生表,一个是学生成绩表. 表的数据有: 一.内连接-inner ...
- 【SQL查询】集合查询之INTERSECT
[SQL查询]集合查询之INTERSECT 1 BLOG文档结构图 2 前言部分 2.1 导读和注意事项 各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其它你所不知道的知识,~ ...
- SQL表连接查询
SQL表连接查询(inner join.full join.left join.right join) 表的数据有: 一.内连接-inner jion : 最常见的连接查询可能是这样,查出学生的名字和 ...
- 数据库——SQL数据连接查询
连接查询 查询结果或条件涉及多个表的查询称为连接查询SQL中连接查询的主要类型 广义笛卡尔积 等值连接(含自然连接) 自身连接查询 外连接查询 一.广义笛卡尔积 不带连 ...
- SQL基础--查询之四--集合查询
SQL基础--查询之四--集合查询
- 浅谈sql之连接查询
SQL之连接查询 一.连接查询的分类 sql中将连接查询分成四类: 内链接 外连接 左外连接 右外连接 自然连接 交叉连接 二.连接查询的分类 数据库表如下: 1.学生表 2.老师表 3.班级表 表用 ...
- 【SQL】各取所需 | SQL JOIN连接查询各种用法总结
前面 在实际应用中,大多的查询都是需要多表连接查询的,但很多初学SQL的小伙伴总对各种JOIN有些迷糊.回想一下,初期很长一段时间,我常用的似乎也就是等值连接 WHERE 后面加等号,对各种JOIN也 ...
- Linq连接查询之左连接、右连接、内连接、全连接、交叉连接、Union合并、Concat连接、Intersect相交、Except与非查询
内连接查询 内连接与SqL中inner join一样,即找出两个序列的交集 Model1Container model = new Model1Container(); //内连接 var query ...
- Oracle组函数、多表查询、集合运算、数据库对象(序列、视图、约束、索引、同义词)等
count组函数:(过滤掉空的字段) select count(address),count(*) from b_user max() avg() min(),sum() select sum(age ...
随机推荐
- 模块 subprocess 交互shell
subprocess 交互shell 执行shell命令, 与操作系统交互 三种执行命令的方法 subprocess.run(*popenargs, input=None, timeout=None, ...
- Django-使用 include() 配置 URL
如果项目非常庞大,应用非常多,应用的 URL 都写在根 urls.py 配置文件中的话,会显的非常杂乱,还会出现名称冲突之类的问题,这样对开发整个项目是非常不利的. 可以这样解决,把每个应用的 URL ...
- NKOJ4238 天天爱跑步(【NOIP2016 DAY1】)
问题描述 小C同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.<天天爱跑步>是一个养成类游戏,需要玩家每天按时上线,完成打卡任务. 这个游戏的地图可以看作一棵包 ...
- 透过源码分析ArrayList运作原理
List接口的主要实现类ArrayList,是线程不安全的,执行效率高:底层基于Object[] elementData 实现,是一个动态数组,它的容量能动态增加和减少.可以通过元素下标访问对象,使用 ...
- 1013 Battle Over Cities (25 分)
It is vitally important to have all the cities connected by highways in a war. If a city is occupied ...
- JS数据结构与算法 - 二叉树(一)基本算法
仅供JavaScript刷题参考用. 二叉查找树和平衡二叉树 其它树:满二叉树.完全二叉树.完美二叉树.哈弗曼树.二叉查找树BST.平衡二叉树AVL 了解:红黑树,是一种特殊的二叉树.这种树可以进行高 ...
- Y分形的平面微带天线生成过程
Y分形的平面微带天线生成过程 本文介绍了使用Altium Designer脚本程序生成Y型天线的过程,在窗体中线宽.迭代次数,边框长度可以直接设置. Y分形天线用户界面由一个窗体.1个TImage控件 ...
- scratch 如何改变变量的作用域
在新建变量的时候,有个选项是“适用于所有角色”还是“仅适用于当前角色”.通常称前者为全局变量,所有角色都可以访问到这个变量:后者,称为局部变量,只能在当前角色里访问到这个变量.例如,在使用克隆功能时, ...
- (29)ASP.NET Core3.1 Swagger(OpenAPI)
1.什么是Swagger/OpenAPI? Swagger是一个与语言无关的规范,用于描述REST API.因为Swagger项目已捐赠给OpenAPI计划,所以也叫OpenAPI.它允许计算机和人员 ...
- golang+docker 进入镜像测试本地通信
首先进入docker镜像: docker-compose exec 镜像 sh //进入镜像 然后添加curl命令 apk add curl 最后在使用 curl -d localhost:809 ...