多數sql查詢只包含從一個或多個表中返回數據的單條select語句.
但是,sql也允許執行多個查詢(多條select語句),并將結果作為一個查詢結果集返回.
這些組合查詢通常稱為(union)或者復合查詢
主要有兩種情況需要使用組合查詢
* 在一個查詢中從不同的表返回結構數據
* 對一個表執行多個查詢,按一個查詢返回數據
**組合查詢和多個where條件**
多數條件下,組合相同表的兩個查詢所完成的工作與具有多個where子句條件的一個查詢所完成的工作相同,換句話說,任何具有多個where子句的select語句都可以作為一個組合查詢
**創建組合查詢**
可用union操作符來組合數條sql查詢,利用union,可給出多條select語句,將他們的結果組合成一個結果集
**使用union**
使用union很簡單,所要做的只是給出每條select語句,在各語句之間放上關鍵字union

**包含或取消重復的行**
注意在分別執行語句時,第一條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與數據類型優化
- 選擇優化的數據類型
- 日期和時間類型
- 標識列
- 特殊類型數據
- 表設計中的缺陷
- 范式
- 計數器表
- 第五章 創建高性能索引
- 索引基礎
- 索引類型
- 索引的優點
- 高性能索引策略
- 選擇合適的索引列順序
- 聚簇索引
- 順序的主鍵什么時候會造成更壞的后果
- 覆蓋索引
- 使用索引掃描來做排序
- 壓縮索引
- 冗余和重復索引
- 索引和鎖
- 支持多種過濾條件
- 什么是范圍條件
- 優化排序
- 維護索引和表
- 表損壞
- 減少索引和數據的碎片
- 第六章 查詢性能優化
- 掃描的行數和訪問類型
- 重構查詢方式
- 查詢執行的基礎
- 重構-改善既有代碼設計
- 第一章-重構
- 什么是重構
- 第一個案列
- 重構第一步
- 王垠博客
- 多態取代價格相關邏輯