MySQL的keylen是指索引列的長(zhǎng)度,通常是指存儲(chǔ)在索引中的字節(jié)數(shù)。在MySQL中,每個(gè)索引列都有一個(gè)相應(yīng)的keylen值,對(duì)于不同的列類(lèi)型,其對(duì)應(yīng)的keylen值也不同。
例如,對(duì)于一個(gè)VARCHAR(50)類(lèi)型的列,其keylen值為50,而對(duì)于INT(11)類(lèi)型的列,其keylen值為4,因?yàn)镮NT(11)類(lèi)型占用4個(gè)字節(jié)的存儲(chǔ)空間。KEYLEN值的大小對(duì)于查詢性能有非常大的影響。
在MySQL中,如果keylen值的長(zhǎng)度超過(guò)了物理塊的大小(默認(rèn)為16KB),那么索引將分裂為多個(gè)塊,從而造成更多的磁盤(pán)I/O,從而降低查詢性能。
一些實(shí)踐經(jīng)驗(yàn)表明,建立較大的索引可以提高查詢速度,避免多次掃描表,但也要注意keylen值不應(yīng)過(guò)大,否則會(huì)造成過(guò)多的磁盤(pán)I/O,影響查詢性能。