mySQL datatypes - why is there a number after int: int(11)
According to the mySQL Docs a datatype of int (signed) has a range of -2147483648 to 2147483647. When I create a table with phpMyAdmin, and expor开发者_StackOverflowt the table structure it shows the following:
`unit_id` int(11) NOT NULL
Why the (11)? Doesn't int
tell mySQL everything it needs to know?
This is the optional 'width' attribute, which can be used by applications to display the value.
To quote the documentation:
MySQL supports an extension for optionally specifying the display width of integer data types in parentheses following the base keyword for the type. For example,
INT(4)
specifies anINT
with a display width of four digits. This optional display width may be used by applications to display integer values having a width less than the width specified for the column by left-padding them with spaces. (That is, this width is present in the metadata returned with result sets. Whether it is used or not is up to the application.)The display width does not constrain the range of values that can be stored in the column. Nor does it prevent values wider than the column display width from being displayed correctly. For example, a column specified as
SMALLINT(3)
has the usualSMALLINT
range of-32768
to32767
, and values outside the range permitted by three digits are displayed in full using more than three digits.
That sets the display width which is returned with the result set. It has no bearing on the storage size.
精彩评论