日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
SQLServer排序遇到NULL,不怕不帕!

此文章主要介紹的是當(dāng)SQL Server排序時遇到NULL的實際解決方案,對于這個問題,可以說被提及的頻率,居高不下,其主要是是客戶之前使用的是Oracle數(shù)據(jù)庫,那么他在使用SQL Server的時候會有一個疑問,就是在處理NULL值上面,SQL Server與Oracle的行為不一樣 。

黃岡ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:028-86922220(備注:SSL證書合作)期待與您的合作!

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

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

則會看到如下的效果

那么,有沒有什么辦法讓SQL Server的這個默認(rèn)機(jī)制與Oracle一樣嗎?答案是:沒有

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

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

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

如果該列有創(chuàng)建索引,那么可以看到如下的執(zhí)行計劃

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

上述的相關(guān)內(nèi)容就是對SQL Server排序時遇上了NULL值的描述,希望會給你帶來一些幫助在此方面。


當(dāng)前文章:SQLServer排序遇到NULL,不怕不帕!
網(wǎng)頁路徑:http://m.5511xx.com/article/dhiogod.html