<bdo id="vljxk"><rt id="vljxk"><noframes id="vljxk"><noframes id="vljxk"><noframes id="vljxk"><rt id="vljxk"></rt><rt id="vljxk"></rt><noframes id="vljxk"><rt id="vljxk"><delect id="vljxk"></delect></rt><noframes id="vljxk"><rt id="vljxk"></rt><noframes id="vljxk"><noframes id="vljxk"><rt id="vljxk"></rt>

當前位置:首頁 >  站長 >  數據庫 >  正文

SQL SERVER臨時表排序問題的解決方法

 2021-02-01 16:58  來源: 腳本之家   我來投稿 撤稿糾錯

  阿里云優惠券 先領券再下單

這篇文章主要給大家介紹了關于SQL SERVER臨時表排序問題的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

在SQL SERVER 2005/2008中,如果將有序的記錄插入臨時表,則從臨時表查詢出來的記錄是有序的(不依賴ORDER BY也是有序狀態),但是從SQL SERVER 2012開始,即使插入的記錄集有序,查詢出來的結果變成無序了。需要依賴ORDER BY來或得到一個有序結果。例如下面例子:

 如上所示,SQL SERVER 2014則是無序狀態,我很是奇怪怎么從SQL SERVER 2012就開始變成無序了,這對我們來說猶如一個黑盒子,只知道結果集出現了變化,但是不知道內部啥變化導致這個現象出現。Records not sorted in the table when using ORDER BY clause to insert data into Temp Table 官方論壇對這個問題的描述如下:

 如果有特殊的需要,要求臨時表里面的數據有序,則可以通過創建聚集索引來解決這個問題。如下所示:

SELECT * INTO #tables FROM sys.tables WHERE 1= 0;

CREATE CLUSTERED INDEX IDX_#tables_NAME ON #tables(name);

INSERT INTO #tables SELECT * FROM sys.tables ORDER BY name;

SELECT * FROM #tables;

總結

到此這篇關于SQL SERVER臨時表排序問題解決的文章就介紹到這了,更多相關SQL SERVER臨時表排序問題內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

來源:腳本之家

鏈接:https://www.jb51.net/article/204331.htm

申請創業報道,分享創業好點子。點擊此處,共同探討創業新機遇!

相關標簽
sqlserver

相關文章

熱門排行

信息推薦