好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > MySQL利用UNION連接2個查詢排序失效詳解

MySQL利用UNION連接2個查詢排序失效詳解

熱門標(biāo)簽:巫師三血與酒地圖標(biāo)注 在哪里申請400電話 走過哪個省地圖標(biāo)注 銷售語音電話機器人 外呼系統(tǒng)電銷受騙 安徽ai電話電銷機器人有效果嗎 萊西市地圖標(biāo)注 400電話申請信用卡 常州網(wǎng)絡(luò)外呼系統(tǒng)開發(fā)

概述

UNION

連接數(shù)據(jù)集關(guān)鍵字,可以將兩個查詢結(jié)果集拼接為一個,會過濾掉相同的記錄

UNION ALL

連接數(shù)據(jù)集關(guān)鍵字,可以將兩個查詢結(jié)果集拼接為一個,不會過濾掉相同的記錄

今天在接到一個需求的時候使用了UNION進行查詢后發(fā)現(xiàn),如果兩個查詢分別使用ORDER BY后拼接居然無法成功排序,經(jīng)過了好一番折騰,記錄下

表結(jié)構(gòu)及數(shù)據(jù)

-- 創(chuàng)建表
CREATE TABLE test_user (
 ID int(11) NOT NULL AUTO_INCREMENT,
 USER_ID int(11) DEFAULT NULL COMMENT '用戶賬號',
 USER_NAME varchar(255) DEFAULT NULL COMMENT '用戶名',
 AGE int(5) DEFAULT NULL COMMENT '年齡',
 COMMENT varchar(255) DEFAULT NULL COMMENT '簡介',
 PRIMARY KEY (ID)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;
 
-- 數(shù)據(jù)插入語句
INSERT INTO test_user (ID, USER_ID, USER_NAME, AGE, COMMENT) VALUES ('1', '111', '開心菜鳥', '18', '今天很開心');
INSERT INTO test_user (ID, USER_ID, USER_NAME, AGE, COMMENT) VALUES ('2', '222', '悲傷菜鳥', '21', '今天很悲傷');
INSERT INTO test_user (ID, USER_ID, USER_NAME, AGE, COMMENT) VALUES ('3', '333', '認真菜鳥', '30', '今天很認真');
INSERT INTO test_user (ID, USER_ID, USER_NAME, AGE, COMMENT) VALUES ('4', '444', '高興菜鳥', '18', '今天很高興');
INSERT INTO test_user (ID, USER_ID, USER_NAME, AGE, COMMENT) VALUES ('5', '555', '嚴(yán)肅菜鳥', '21', '今天很嚴(yán)肅');

默認表數(shù)據(jù)顯示如下


運行結(jié)果分析

-- 查詢1
SELECT
 *
FROM
 test_user u
ORDER BY AGE

結(jié)果集1


-- 查詢2
-- 使用UNION
(
 SELECT
  *
 FROM
  test_user u
 ORDER BY AGE
)
UNION
(
 SELECT
  *
 FROM
  test_user u
 ORDER BY AGE
);
 
-- 查詢3
-- 使用UNION ALL
(
 SELECT
  *
 FROM
  test_user u
 ORDER BY AGE
)
UNION ALL
(
 SELECT
  *
 FROM
  test_user u
 ORDER BY AGE
)

結(jié)果集2:使用UNION

由于UNION會合并相同的記錄(與DISTINCT實現(xiàn)相同效果),因此此處顯示僅有5條記錄

結(jié)果集3:使用UNION ALL

如果需要使用UNION ALL又需要進行排序,則要將其作為一個子查詢來查

-- 查詢4
-- 將UNION ALL作為子查詢并進行排序
SELECT
 *
FROM
 (
 (
 SELECT
 *
 FROM
 test_user u
 ORDER BY
 AGE
 )
 UNION ALL
 (
 SELECT
 *
 FROM
 test_user u
 ORDER BY
 AGE
 )
 ) a
ORDER BY
 AGE;

結(jié)果集4

 改進

在經(jīng)過一番搜索相關(guān)的經(jīng)驗后發(fā)現(xiàn),是我之前有些畫蛇添足了,原來可以在不使用子查詢即可完成排序的方法:

-- 查詢5
-- 第一個查詢不使用排序,如果使用的話不加括號會報錯(這也是我之前為什么會想用子查詢的原因而沒有想過這種方式了)
SELECT
 *
FROM
 test_user u
 
UNION ALL
 
SELECT
 *
FROM
 test_user u
ORDER BY
 AGE

運行出來的結(jié)果集與結(jié)果集4是相同的,此處就不再粘出結(jié)果。

結(jié)論

當(dāng)我們使用UNION(或者UNION ALL)語句時,如果UNION的兩個結(jié)果集在單獨排序后再拼接,則他們的ORDER BY是失效的。如果我們要進行排序有以下兩種方法:

  1. 將它們作為子查詢再ORDER BY查詢一次(還是建議使用方法2,子查詢太不簡潔了)
  2. 在第一個結(jié)果集中不使用排序,且不用括號分隔,而在第二個結(jié)果集后使用ORDER BY

參考鏈接

cnblogs:MySQL中UNION和UNION ALL的使用

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • php7連接MySQL實現(xiàn)簡易查詢程序的方法
  • Mysql join連接查詢的語法與示例
  • mysql連接查詢、聯(lián)合查詢、子查詢原理與用法實例詳解
  • python針對mysql數(shù)據(jù)庫的連接、查詢、更新、刪除操作示例
  • Mysql自連接查詢實例詳解
  • 詳解MySQL數(shù)據(jù)庫--多表查詢--內(nèi)連接,外連接,子查詢,相關(guān)子查詢
  • mysql多表連接查詢實例講解
  • mysql多個left join連接查詢用法分析
  • JDBC連接MySql數(shù)據(jù)庫步驟 以及查詢、插入、刪除、更新等
  • mysql連接查詢(左連接,右連接,內(nèi)連接)
  • MySQL 連接查詢的原理和應(yīng)用

標(biāo)簽:煙臺 河北 鞍山 赤峰 果洛 黃石 來賓 陽江

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL利用UNION連接2個查詢排序失效詳解》,本文關(guān)鍵詞  MySQL,利用,UNION,連接,2個,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL利用UNION連接2個查詢排序失效詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySQL利用UNION連接2個查詢排序失效詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 用精油按摩达到高淖潮| 669aaa免费大片| 国产啪视频| 国产九九精品视频| 三上悠亚的第一部作品| 91久久久久久精品国元产码| 局长太大太粗进不去 | 精品国产一区二区三区四区特色 | 美女露出尿囗让男人桶爽快| 电影野性的欢愉在线观看| 午夜影视污| 天天摸日日舔| 强伦妺妺的第一次好紧H小说| 尹人香蕉久久99天天拍欧美p7 | 欧美三级 欧美一级| 午夜一区二区免费视频| cao美女视频网站在线观看| 欧美另类熟妇XXXX久久A片| 久久免费人成看片中文无码av| 中文在线1区二区六区| 91色影院| www.狠狠操.com| 久久99综合国产精品色| 日本边摸边吃奶边做免费观看| 成人黄软件网18免费下载| 精品无码A∨一区二区三区少奶| 最好看最新日本中文字幕| 国产亚洲sss在线播放| 亚洲熟女丰满多毛XXXX麻豆| 公车全黄H全肉短篇公车之狼| 人体大胆a级照片| 日本电影家庭教师| 好男人好资源在线观看免费官网| japanese熟睡侵犯| 看黄色a级片| 麻豆传播媒体app入口下载官网免费| 亚洲AV国产AV精品美女| 啊~cao死你个小sao货| 天天射日日| 美女被男人操的视频| 国产精品v欧美精品v日韩|