多数sql查询只包含从一个或多个表中返回数据的单条select语句.
但是,sql也允许执行多个查询(多条select语句),并将结果作为一个查询结果集返回.
这些组合查询通常称为(union)或者复合查询
主要有两种情况需要使用组合查询
* 在一个查询中从不同的表返回结构数据
* 对一个表执行多个查询,按一个查询返回数据
**组合查询和多个where条件**
多数条件下,组合相同表的两个查询所完成的工作与具有多个where子句条件的一个查询所完成的工作相同,换句话说,任何具有多个where子句的select语句都可以作为一个组合查询
**创建组合查询**
可用union操作符来组合数条sql查询,利用union,可给出多条select语句,将他们的结果组合成一个结果集
**使用union**
使用union很简单,所要做的只是给出每条select语句,在各语句之间放上关键字union
![](https://box.kancloud.cn/5366dbfd9b05377f3c64e475148f021b_1076x400.png)
**包含或取消重复的行**
注意在分别执行语句时,第一条select语句返回3行,第二条select语句返回2行.而在用union组合两条select语句后,只返回4行而不是5行
union从查询结果集中自动去除了重复的行,换句话说,它的行为与一条select语句中使用多个where子句条件一样.使用union时,重复的行会被自动取消
这是union的默认行为,如果愿意也可以改变他.事实上,如果想返回所有的匹配行,可使用union all而不是union
**union与where**
union几乎总是完成与多个where条件相同的工作.union all为union的一种形式,他完成where子句完成不了的工作.
如果确实需要每个条件的匹配行全部出现(包括重复行),就必须使用union all,而不是where
**对组合查询排序**
select语句的输出用order by子句排序.在用union组合查询时,只能使用一条order by子句,他必须位于最后一条select语句之后.对于结果集,不存在用一种方式排序一部分,而又用另一种方式排序另一部分的情况,因此不允许使用多条order by子句
- 书列表
- laravel框架关键技术
- 第一章 组件化开发与composer使用
- 简介
- composer
- 添加路由组件
- 添加控制器模块
- 添加模型组件
- 添加视图组件
- 第三章 laravel框架中常用的php语法
- 匿名函数
- 文件包含
- 魔术方法
- 魔术常量
- 反射
- 后期静态绑定
- traits
- 第四章 laravel框架中使用的HTTP协议基础
- HTTP协议
- 数据库
- 数据迁移
- 第六章 laravel框架中的设计模式
- IOC模式
- php核心技术与最佳实践
- 第一章面向对象核心
- 反射
- 简单ORM
- 异常和错误
- 接口
- 第二章,面向对象设计
- 设计原则
- 单一职责
- 接口隔离
- 开放封闭
- 替换原则
- 依赖倒置
- linux是怎么写的呢?
- 第三章 正则表达
- 认识正则
- 第四章 php网络技术应用
- HTTP协议详解
- php和http相关函数
- 垃圾信息防御措施
- 现代操作系统
- 引论
- sql必知必会
- 限制结果
- 按位置排序
- where求职顺序
- IN操作符
- like
- 函数
- group by
- 组合查询
- 插入检索出的数据
- 视图
- 高性能mysql
- 第一章节 mysql架构与历史
- mysql架构逻辑图
- 连接与管理
- 优化与运行
- 读写锁
- 锁粒度
- 表锁(table lock)
- 行级锁(row lock)
- ACID
- 隔离级别
- 死锁
- 隐式和显式锁定
- 多版本并发控制
- Innodb概览
- 第四章节 Schema与数据类型优化
- 选择优化的数据类型
- 日期和时间类型
- 标识列
- 特殊类型数据
- 表设计中的缺陷
- 范式
- 计数器表
- 第五章 创建高性能索引
- 索引基础
- 索引类型
- 索引的优点
- 高性能索引策略
- 选择合适的索引列顺序
- 聚簇索引
- 顺序的主键什么时候会造成更坏的后果
- 覆盖索引
- 使用索引扫描来做排序
- 压缩索引
- 冗余和重复索引
- 索引和锁
- 支持多种过滤条件
- 什么是范围条件
- 优化排序
- 维护索引和表
- 表损坏
- 减少索引和数据的碎片
- 第六章 查询性能优化
- 扫描的行数和访问类型
- 重构查询方式
- 查询执行的基础
- 重构-改善既有代码设计
- 第一章-重构
- 什么是重构
- 第一个案列
- 重构第一步
- 王垠博客
- 多态取代价格相关逻辑