根據個人的實驗並結合資料:
1、長度跟可以使用的值的范圍無關,值的范圍僅跟類型對應的存儲字節數和是否unsigned有關;
2、長度指的是顯示寬度,比如,指定3位int,那么id為3和id為300的值,在顯示的時候怎么對齊呢?按照手冊的說法,是默認用“空格”在左邊填充。比如下述表格
CREATE TABLE `inttest` ( `id` int(3) unsigned NOT NULL AUTO_INCREMENT, `value` varchar(2) NOT NULL, PRIMARY KEY (`id`) ) EN
現在分別插入id長度為2,3,4,5位的數據,執行查詢以后得到顯示如下:
MariaDB [mytest]> select * from inttest; +-------+-------+ | id | value | +-------+-------+ | 13 | a | | 111 | b | | 1000 | c | | 10000 | d | +-------+-------+ 4 rows in set (0.00 sec)
如果我們改成ZEROFILL,再次查詢的結果如下:
MariaDB [mytest]> select * from inttest; +-------+-------+ | id | value | +-------+-------+ | 013 | a | | 111 | b | | 1000 | c | | 10000 | d | +-------+-------+ 4 rows in set (0.00 sec)
我們會發現,不足3位長度的值會被自動填充,而超過3位長度的值就不會被填充了。
以下是mysql官網對於設置寬度的解釋:
“MySQL還支持選擇在該類型關鍵字后面的括號內指定整數值的顯示寬度(例如,INT(4))。該可選顯示寬度規定用於顯示寬度小於指定的列寬度的值時從左側填滿寬度。顯示寬度並不限制可以在列內保存的值的范圍,也不限制超過列的指定寬度的值的顯示。“
“當結合可選擴展屬性ZEROFILL使用時, 默認補充的空格用零代替。例如,對於聲明為INT(5) ZEROFILL的列,值4檢索為00004。請注意如果在整數列保存超過顯示寬度的一個值,當MySQL為復雜聯接生成臨時表時會遇到問題,因為在這些情況下MySQL相信數據適合原列寬度。”