溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

SQLServer數(shù)據(jù)庫(kù)中如何使用ISNULL函數(shù)

發(fā)布時(shí)間:2021-07-24 17:27:21 來(lái)源:億速云 閱讀:115 作者:Leah 欄目:數(shù)據(jù)庫(kù)

SQLServer數(shù)據(jù)庫(kù)中如何使用ISNULL函數(shù),很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。

  SQLServer數(shù)據(jù)庫(kù)ISNULL函數(shù)怎么應(yīng)用

  1.利用ISNULL函數(shù)干掉OR運(yùn)算!

  題目是查詢(xún)表中VAL小于20的值,包括NULL值:

  SELECT*FROMTWHEREISNULL(VAL,-1)<20SELECT*FROMTWHEREVALISNULLORVAL<20   兩個(gè)SQL具有相同的輸出結(jié)果   GRP_AGRP_BGRP_CVAL-----------------a1b1c110a1b1c210a2b3c3NULLa2b3c3NULLa2b3c3NULL(5行受影響)   GRP_AGRP_BGRP_CVAL----------------a1b1c110a1b1c210a2b3c3NULLa2b3c3NULLa2b3c3NULL(5行受影響)   SQLServer數(shù)據(jù)庫(kù)ISNULL函數(shù)怎么應(yīng)用   2.ISNULL非主流更新表存儲(chǔ)過(guò)程示例   如某更新表存儲(chǔ)過(guò)程如下:   CREATEPROCUpdateT(@IDINT,@GRP_AVARCHAR(10)=NULL,@GRP_BVARCHAR(10)=NULL,@GRP_CVARCHAR(10)=NULL,@VALINT=0)ASBEGINUPDATETSETGRP_A=@GRP_A,GRP_B=@GRP_B,GRP_C=@GRP_C,VAL=@VALWHEREID=@IDEND   當(dāng)我們使用這個(gè)存儲(chǔ)過(guò)程的時(shí)候,必須先得該行的所有記錄,再把所有記錄更新回去,可是這并不總是必須的。有時(shí)候手頭只有兩個(gè)數(shù)據(jù):ID和VAL,我只想更新這個(gè)VAL,又有時(shí)候手頭有另外兩個(gè)數(shù)據(jù):ID和GRP_A,這時(shí)候只更新GRP_A列即可。還有很多情況,如:   僅更新GRP_A,   僅更新GRP_A,GRP_B   僅更新GRP_A,GRP_B,GRP_C   僅更新GRP_A,GRP_B,GRP_C,VAL   ...   這樣的組合太多了,要想一勞永逸解決問(wèn)題那就得更新任何字段前,先得到整行記錄,再整行更新回去,于是多了一項(xiàng)工作:先查詢(xún),再更新,那沒(méi)有辦法不先查詢(xún)直接更新某一列呢而且列可以任意組合   在給出答案前,先聲明一句:這個(gè)方法算不上完美解決方案,僅僅是個(gè)思路罷了,雖然我一直認(rèn)為沒(méi)什么影響,但假如要在正式項(xiàng)目中使用,建議還是多聽(tīng)聽(tīng)DBA的意見(jiàn)!   非主流更新任意列存儲(chǔ)過(guò)程:   CREATEPROCUpdateT(@IDINT,@GRP_AVARCHAR(10)=NULL,@GRP_BVARCHAR(10)=NULL,@GRP_CVARCHAR(10)=NULL,@VALINT=0)ASBEGINUPDATETSETGRP_A=ISNULL(@GRP_A,GRP_A),GRP_B=ISNULL(@GRP_B,GRP_B),GRP_C=ISNULL(@GRP_C,GRP_C),VAL=ISNULL(@VAL,VAL)WHEREID=@IDEND  

看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝您對(duì)億速云的支持。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI