您的位置主页 > 数据库专区 > Mysql > int(M) M的实际意义

int(M) M的实际意义

2010-06-14    文章来源:互联网    浏览次数:1771     分享文章

    MySQL 数据类型中的 integer types 有点奇怪。你可能会见到诸如:int(3)、int(4)、int(8) 之类的 int 数据类型。刚接触 MySQL 的时候,我还以为 int(3) 占用的存储空间比 int(4) 要小, int(4) 占用的存储空间比 int(8) 小。

    后来,参看 MySQL 手册,发现自己理解错了。

    int(M): M indicates the maximum display width for integer types.

    在 integer 数据类型中,M 表示最大显示宽度。

    原来,在 int(M) 中,M 的值跟 int(M) 所占多少存储空间并无任何关系。 int(3)、int(4)、int(8) 在磁盘上都是占用 4 btyes 的存储空间。说白了,除了显示给用户的方式有点不同外,int(M) 跟 int 数据类型是相同的。

    这个可选的宽度规格说明是用于在数值显示时,对某些值的宽度短于该列宽度的值进行左填补显示的,而不是为了限制在该列中存储值的宽度,也不是为了限制那些超过该列指定宽度的值的可被显示的数字位数。当与可选的扩展属性 ZEROFILL 一起使用时,缺省填补用的空格被零代替。int(M) 只有跟 zerofill 结合起来,才能使我们清楚的看到不同之处。

mysql> drop table if exists t;
mysql> create table t(id int zerofill);
mysql> insert into t(id) values(10);
mysql> select * from t;
+------------+
| id         |
+------------+
| 0000000010 |
+------------+
mysql> alter table t change column id id int(3) zerofill;
mysql> select * from t;
+------+
| id   |
+------+
| 010  |
+------+
mysql> alter table t change column id id int(4) zerofill;
mysql> select * from t;
+------+
| id   |
+------+
| 0010 |
+------+
mysql> insert into t(id) values(1000000);
mysql> select * from t;
+---------+
| id      |
+---------+
| 0010    |
| 1000000 |
+---------+
    从上面的测试可以看出,"(M)"指定了 int 型数值显示的宽度,如果字段数据类型是 int(4),则:当显示数值 10 时,在左边要补上 "00";当显示数值 100 是,在左边要补上"0";当显示数值 1000000 时,已经超过了指定宽度"(4)",因此按原样输出。

    那如果,你在一个int(2),插入一个超过2位的数字,比如123156.会怎么样?

    我来告诉你答案,不会怎么样,正常插入,什么错误也没有,正常显示123156。

    不过听说mysql在复杂联表查询时,需要要生成临时表时,如果在一个整型列中存储一个超过显示宽度的更大值时可能会遇到问题,因为在这种情况下,MySQL 信任地认为所有的值均适合原始的列宽度。 (暂时我也没测出来)
 

文章评论(查看全部)

昵 称 *
电子邮箱 *
网 址      6 + 8 = ?
管理员 发表于:2011/02/12 15:00
谢谢你的支持,友情链接我加好了,请查
kukaka:这个好啊
管理员 发表于:2011/02/12 14:50
谢谢你的支持,友情链接我加好了,请查
kukaka:这个好啊
管理员 发表于:2011/02/12 14:46
谢谢你的支持,友情链接我加好了,请查
kukaka:这个好啊
管理员 发表于:2011/02/12 14:37
test
kukaka:这个好啊
kukaka 发表于:2010/11/19 11:06
这个好啊