溫馨提示×

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

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

MySQL中NULL對(duì)索引的影響有哪些

發(fā)布時(shí)間:2021-07-30 11:19:55 來(lái)源:億速云 閱讀:2125 作者:小新 欄目:MySQL數(shù)據(jù)庫(kù)

小編給大家分享一下MySQL中NULL對(duì)索引的影響有哪些,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

在mysql5.6和5.7下均可,存儲(chǔ)引擎為InnoDB。

數(shù)據(jù)如下:

MySQL中NULL對(duì)索引的影響有哪些

1. 單列索引

給name列建單列索引:

MySQL中NULL對(duì)索引的影響有哪些

查詢(xún)name為null的行:

MySQL中NULL對(duì)索引的影響有哪些

查詢(xún)name為'test0'或?yàn)閚ull的行:

MySQL中NULL對(duì)索引的影響有哪些

可以發(fā)現(xiàn)都可以用到索引。

2. 聯(lián)合索引

給age和name添加聯(lián)合索引:

MySQL中NULL對(duì)索引的影響有哪些

查詢(xún)age為14并且name為null的行:

MySQL中NULL對(duì)索引的影響有哪些

可以發(fā)現(xiàn)同樣用到了索引。

3. 其他

雖然MySQL可以在含有null的列上使用索引,但不代表null和其他數(shù)據(jù)在索引中是一樣的。

不建議列上允許為空。最好限制not null,并設(shè)置一個(gè)默認(rèn)值,比如0和''空字符串等,如果是datetime類(lèi)型,可以設(shè)置成'1970-01-01 00:00:00'這樣的特殊值。

對(duì)MySQL來(lái)說(shuō),null是一個(gè)特殊的值,Conceptually, NULL means “a missing unknown value” and it is treated somewhat differently from other values。比如:不能使用=,<,>這樣的運(yùn)算符,對(duì)null做算術(shù)運(yùn)算的結(jié)果都是null,count時(shí)不會(huì)包括null行等,null比空字符串需要更多的存儲(chǔ)空間等。

看完了這篇文章,相信你對(duì)“MySQL中NULL對(duì)索引的影響有哪些”有了一定的了解,如果想了解更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

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

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎ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