SQL Server排序遇到NULL,不怕不帕!
此文章主要介紹的是當(dāng)SQL Server排序時(shí)遇到NULL的實(shí)際解決方案,對(duì)于這個(gè)問(wèn)題,可以說(shuō)被提及的頻率,居高不下,其主要是是客戶之前使用的是Oracle數(shù)據(jù)庫(kù),那么他在使用SQL Server的時(shí)候會(huì)有一個(gè)疑問(wèn),就是在處理NULL值上面,SQL Server與Oracle的行為不一樣 。
在Oracle中,NULL值會(huì)認(rèn)為是一個(gè)無(wú)窮大的值,所以如果按照升序排列的話,則會(huì)被排在***面在SQL Server中則正好相反,NULL值會(huì)被認(rèn)為是一個(gè)無(wú)窮小的值,所以如果按照升序排列的話,則會(huì)被排在最前面
如
- SELECT [ID]
- FROM [demo].[dbo].[Orders] Order By ID
則會(huì)看到如下的效果
那么,有沒(méi)有什么辦法讓SQL Server的這個(gè)默認(rèn)機(jī)制與Oracle一樣嗎?答案是:沒(méi)有
但我們可以想一些變通的辦法,例如可以像下面這樣寫代碼
- SELECT [ID]
- FROM [demo].[dbo].[Orders] Order By CASE WHEN ID IS NULL THEN 1 ELSE 0 END
這樣的話,就可以看到如下的效果
如果該列有創(chuàng)建索引,那么可以看到如下的執(zhí)行計(jì)劃
但是,仍然還有其他的一種解決方案,可以把該列的默認(rèn)值設(shè)置為一個(gè)很大的值,也就是說(shuō),如果用戶無(wú)法提供該列的值,則默認(rèn)用一個(gè)很大的數(shù)字代替。如果是INT型,這個(gè)數(shù)字,可以是2147483647。這樣的情況下,如果排序的時(shí)候當(dāng)然就不需要再進(jìn)行判斷了。
上述的相關(guān)內(nèi)容就是對(duì)SQL Server排序時(shí)遇上了NULL值的描述,希望會(huì)給你帶來(lái)一些幫助在此方面。
【編輯推薦】
- SQL Server 2008數(shù)據(jù)庫(kù)中正確的對(duì)驗(yàn)證數(shù)據(jù)挖掘模型
- SQL Server identity列,美中不足之處
- SQL Server DateTime數(shù)據(jù)類型的另類解讀
- MS SQL Server數(shù)據(jù)庫(kù)快速獲得表的記錄總數(shù)步驟
- SQL Server 2000的安全策略的正確打造