程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> 當SQL Server排序時遇上了NULL值

當SQL Server排序時遇上了NULL值

編輯:關於SqlServer

這是一個經常被問到的問題。尤其是客戶之前使用的是Oracle,那麼他在使用SQL Server的時候會有 一個疑問,就是在處理NULL值上面,SQL Server與Oracle的行為不一樣

在Oracle中,NULL值會認為是一個無窮大的值,所以如果按照升序排列的話,則會被排在最後面

在SQL Server中則正好相反,NULL值會被認為是一個無窮小的值,所以如果按照升序排列的話,則會 被排在最前面

SELECT [ID]
  FROM [demo].[dbo].[Orders] Order By ID

則會看到如下的效果

那麼,有沒有什麼辦法讓SQL Server的這個默認機制與Oracle一樣嗎?答案是:沒有

但我們可以想一些變通的辦法,例如可以像下面這樣寫代碼

SELECT [ID]

FROM [demo].[dbo].[Orders] Order By CASE WHEN ID IS NULL THEN 1 ELSE 0 END

這樣的話,就可以看到如下的效果

如果該列有創建索引,那麼可以看到如下的執行計劃

但是,仍然還有其他的一種解決方案,可以把該列的默認值設置為一個很大的值,也就是說,如果用 戶無法提供該列的值,則默認用一個很大的數字代替。如果是INT型,這個數字,可以是2147483647。這 樣的情況下,如果排序的時候當然就不需要再進行判斷了。

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