mysql中為int設定長度究竟是什麼意思

來源:互聯網
上載者:User

標籤:

根據個人的實驗並結合資料:
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相信資料適合原列寬度。

mysql中為int設定長度究竟是什麼意思

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.