程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> Mysql結合查詢UNION和Order by同時應用報錯成績的處理方法

Mysql結合查詢UNION和Order by同時應用報錯成績的處理方法

編輯:MySQL綜合教程

Mysql結合查詢UNION和Order by同時應用報錯成績的處理方法。本站提示廣大學習愛好者:(Mysql結合查詢UNION和Order by同時應用報錯成績的處理方法)文章只能為提供參考,不一定能成為您想要的結果。以下是Mysql結合查詢UNION和Order by同時應用報錯成績的處理方法正文


是以,經常湧現如許的毛病

select * from [IND] where INDID>10
union
select * from [IND] where INDID<9
今朝為止,還沒有湧現問

以後,或許有人會用到相似的查詢

select * from [IND] where INDID>10 order by INDID desc
union
select * from [IND] where INDID<9 order by INDID desc
此時就湧現成績了,數據庫報錯。成績就出在order by上

為何呢?豈非UNION和ORDER BY 不克不及同時存在?

union和 order by 固然是可以同時存在的

然則在應用union的時刻,結合查詢不只僅是將數據聚集歸並
他其實不是將每一個子查詢一個一個查詢出來後聯接在一路,數據庫是將整段查詢語句懂得以後同一查詢獲得的是全部的數據聚集
別的order by在一個數據聚集查詢裡也只能湧現一次而且湧現在最初。
是以,在結合查詢裡,order by 要寫在最初一個子查詢以後,而且,該排序是對全部結合查詢出來的成果集排序的,其實不是只對最初一個子查詢排序
select * from [IND] where INDID>10
union
select * from [IND] where INDID<9 order by INDID desc
如許便可以對我們結合查詢出來的成果集停止全體排序,而不是只對最初一個子查詢的成果集排序。

再做一個實驗來更充足的解釋這個成績

創立一個如許的查詢

select * from [IND] where INDID=4

union

select * from [IND] where INDID=2
union
select * from [IND] where INDID=1
union
select * from [IND] where INDID=5
union
select * from [IND] where INDID=3
INDID是主鍵,在創立數據的時刻,數據庫裡的次序是12345


假如結合查詢只是但存的將查詢成果聯接在一路,那末我們獲得的成果應當是:42153

然則,現實上獲得的成果是和數據庫裡數據分列的次序一樣的 12345

是以,可以得出結論,結合查詢的成果是全部查詢完成後得出的,而不是將子查詢挨個完成後拼接的。

select * from [IND] where INDID=4

union

select * from [IND] where INDID=2
union
select * from [IND] where INDID=1
union
select * from [IND] where INDID=5
union
select * from [IND] where INDID=3

order by INDID ASC/DESC
如許便可以對全部結合成果集停止排尋了。


別的關於TOP?

假如是如許,在通俗的查詢中,TOP是在ORDER BY以後履行的,那末

select TOP 2 * from [IND] where INDID=4

union

select * from [IND] where INDID=2
union
select * from [IND] where INDID=1
union
select * from [IND] where INDID=5
union
select * from [IND] where INDID=3

order by INDID
如許是否是可以獲得全部成果集排序後的最後面兩條數據呢?

謎底是弗成以。

固然說在單句的查詢中,TOP是在ORDER BY 以後履行,然則在結合查詢中,如許寫,TOP的感化域是在子查詢裡,是以TOP並沒有春聯合查詢的成果集挑選,而只對它所寫在的那便條查詢裡停止挑選,這就像是子查詢裡的WHERE語句一樣,相似如許的挑選感化規模都是在子查詢,不像ORDER BY 感化在全部結合查詢。


那末若何春聯合查詢停止 截取置頂N條數據的挑選呢? 很簡略

用 rowcount

比起TOP來講,rowcount作為成果集截取置頂加倍標准些,究竟不是依附查詢語句,而是直接設置查詢語句取得成果集的數量。

set rowcount 2

select * from [IND] where INDID=4

union
select * from [IND] where INDID=1
union
select * from [IND] where INDID=2

union
select * from [IND] where INDID=3

order by INDID ASC
形如以上查詢語句。我們便可以做到春聯合查詢排序,並取得最上的兩條數據了。


既然能應用order by 排序 和 並用rowcount截取集和數目,那末天然結合查詢分頁等其他運用也不在話下了

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved