MySQL資料庫varchar的限制規則說明

來源:互聯網
上載者:User

MySQL資料庫中varchar最大長度是多少?其實這不是一個固定的數字,varchar的長度是有限制規則的。本文我們就來介紹一下MySQL資料庫中varchar的限制規則,並以一個實際的例子對限制規則進行了說明,接下來就讓我們一起來瞭解一下這部分內容。

1、限制規則

欄位的限制在欄位定義的時候有以下規則:

a)儲存限制

varchar欄位是將實際內容單獨儲存在聚簇索引之外,內容開頭用1到2個位元組表示實際長度(長度超過255時需要2個位元組),因此最大長度不能超過65535。

b)編碼長度限制

字元類型若為gbk,每個字元最多佔2個位元組,最大長度不能超過32766;

字元類型若為utf8,每個字元最多佔3個位元組,最大長度不能超過21845。

若定義的時候超過上述限制,則varchar欄位會被強行轉為text類型,併產生warning。

c)行長度限制

導致實際應用中varchar長度限制的是一個行定義的長度。MySQL要求一個行的定義長度不能超過65535。若定義的表長度超過這個值,則提示ERROR1118(42000):Rowsizetoolarge.Themaximumrowsizefortheusedtabletype,notcountingBLOBs,is65535.YouhavetochangesomecolumnstoTEXTorBLOBs。

2、計算例子

舉兩個例說明一下實際長度的計算。

a)若一個表只有一個varchar類型,如定義為createtablet4(cvarchar(N))charset=gbk;則此處N的最大值為(65535-1-2)/2=32766。

減1的原因是實際行儲存從第二個位元組開始';

減2的原因是varchar頭部的2個位元組表示長度;

除2的原因是字元編碼是gbk。

b)若一個表定義為createtablet4(cint,c2char(30),c3varchar(N))charset=utf8;則此處N的最大值為(65535-1-2-4-30*3)/3=21812。

減1和減2的原因與上例相同;

減4的原因是int類型的c佔4個位元組;

減30*3的原因是char(30)佔用90個位元組,編碼是utf8。

如果varchar超過上述的b規則,被強制轉成text類型,則每個欄位佔用定義長度為11位元組,當然這已經不是“varchar”了。

關於MySQL資料庫中varchar的限制規則的知識就介紹到這裡了,希望本次的介紹能夠對您有所收穫!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.