亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL中Union子句不支持order by的解決方法

 更新時(shí)間:2016年06月25日 09:32:18   作者:yiluoAK_47  
這篇文章主要介紹了MySQL中Union子句不支持order by的解決方法,結(jié)合實(shí)例形式分析了在mysql的Union子句中使用order by的方法,需要的朋友可以參考下

本文實(shí)例講述了MySQL中Union子句不支持order by的解決方法。分享給大家供大家參考,具體如下:

我對(duì)DB知之甚少,這問題只在MySQL遇到,不知道別的DBMS是不是也如此。

問題是這樣的,我打算在一個(gè)表里獲得與某一行記錄相鄰的兩行,并且想通過union一起取出來,所以這么寫:

select id,title from subjects where id>#some_id# order by id limit 1
union
select id,title from subjects where id<#some_id# order by id limit 1

但出現(xiàn)了錯(cuò)誤提示“Incorrect usage of UNION and ORDER BY”??磥聿荒苓@么用union和order by,但這里確實(shí)是需要order by的。很快,我想到了一個(gè)變通的寫法:

select * from (
select id,title from subjects where id>#some_id# order by id limit 1
) union
select id,title from subjects where id<#some_id# order by id limit 1

從經(jīng)驗(yàn)上說,第二個(gè)子句該不會(huì)被union影響,可以用order by。于是把第一個(gè)子句包在一個(gè)括號(hào)里,這下應(yīng)該就可以了??墒沁€是有錯(cuò)誤,提示“ Every derived table must have its own alias”。這里的提示是需要給我們括號(hào)里面生成的臨時(shí)表取一個(gè)別名,這個(gè)好辦多了。于是改為:

select * from (
select id,title from subjects where id>#some_id# order by id limit 1
) as t1 union
select id,title from subjects where id<#some_id# order by id limit 1

這條語句成功執(zhí)行并且得到了正確的結(jié)果,在此寫下來備忘。

更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《MySQL日志操作技巧大全》、《MySQL事務(wù)操作技巧匯總》、《MySQL存儲(chǔ)過程技巧大全》、《MySQL數(shù)據(jù)庫(kù)鎖相關(guān)技巧匯總》及《MySQL常用函數(shù)大匯總

希望本文所述對(duì)大家MySQL數(shù)據(jù)庫(kù)計(jì)有所幫助。

相關(guān)文章

最新評(píng)論