這篇文章主要介紹了NULL和唯一約束UNIQUE的對(duì)應(yīng)關(guān)系是什么,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
成都創(chuàng)新互聯(lián)公司長(zhǎng)期為上千多家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺(tái),與合作伙伴共同營(yíng)造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為無(wú)錫企業(yè)提供專業(yè)的網(wǎng)站制作、網(wǎng)站設(shè)計(jì),無(wú)錫網(wǎng)站改版等技術(shù)服務(wù)。擁有十年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。NULL和唯一約束UNIQUE的對(duì)應(yīng)關(guān)系
在數(shù)據(jù)庫(kù)中,NULL表示列值為空。唯一約束UNIQUE規(guī)定指定列的值必須是唯一的,值和值之間都不能相同。這個(gè)時(shí)候,就出現(xiàn)一個(gè)問題,NULL和NULL算是相同,還是不同。由于SQL語(yǔ)法沒有明確規(guī)定,所以各個(gè)數(shù)據(jù)庫(kù)廠商的處理方式不同。
(1)PostgreSQL和Oracle認(rèn)為NULL表示沒有指定數(shù)據(jù),所以數(shù)據(jù)有多種可能,所以UNIQUE約束列中允許存在任意個(gè)NULL。
(2)Informix和SQL Server認(rèn)為NULL就表示空,是一種唯一的狀態(tài)。所以UNIQUE約束列中只能有一個(gè)NULL。
(3)DB2、SQLAnyWhere和InterBase認(rèn)為NULL存在不確定性,無(wú)法比較,所以UNIQUE約束列中不允許有NULL。
而SQLite遵循了PostgreSQL和Oracle的策略,允許UNIQUE約束列中有任意個(gè)NULL。
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“NULL和唯一約束UNIQUE的對(duì)應(yīng)關(guān)系是什么”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!