MySQL中的integer 数据类型
2015-04-09 16:46
1491 查看
钉钉、微博极速扩容黑科技,点击观看阿里云弹性计算年度发布会!>>>
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 数据类型是相同的。
另外,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>
mysql> alter table t change column id id int(4) zerofill;
mysql> select * from t;
+------+
| id |
+------+
| 0010 |
+------+
mysql>
mysql> insert into t(id) values(1000000);
mysql> select * from t;
+---------+
| id |
+---------+
| 0010 |
| 1000000 |
+---------+
从上面的测试可以看出,“(M)”指定了 int 型数值显示的宽度,如果字段数据类型是 int(4),则:当显示数值 10 时,在左边要补上 “00”;当显示数值 100 是,在左边要补上“0”;当显示数值 1000000 时,已经超过了指定宽度“(4)”,因此按原样输出。
在使用 MySQL 数据类型中的整数类型(tinyint, smallint, mediumint, int/integer, bigint)时,非特殊需求下,在数据类型后加个“(M)”,我想不出有何意义。
我看到有人使用 int(100)这样的写法,甚吓煞小僧。我们知道int是4个字节,无符号型的话表示的最大范围是0到4294967295,也就是10位,所以int(11+)这样的定义都是没意义的。你可以插入一个9999999999888888888这样的超大“int”到int字段,但是你会发现,你插进去没用,变了,系统会进行调整。把它变为4294967295或者2147483647这样的极值。
相关文章推荐
- MySQL中的integer 数据类型
- Mysql数据类型---INTEGER
- (转载)MySQL数据类型:TINYINT, SMALLINT, MEDIUMINT, INT, INTEGER等字段类型区别
- MySQL数据类型:TINYINT,SMALLINT,MEDIUMINT,INT,INTEGER,BIGINT;text,longtext,mediumtext,ENUM,SET等字段类型区别
- mysql中数据类型的长度 INTEGER, INT, SMALLINT, TINYINT, MEDIUMINT, BIGINT
- pdo 连接mysql 出现数据类型不一致问题(即全等问题)
- Java数据类型和MySql数据类型对应表
- mysql-数据类型
- MySQL基础之数据类型和运算符
- MySQL 数据类型
- Mysql性能优化之数据类型优化
- MySQL数据类型 YEAR和TIME
- Mysql支持的数据类型
- mysql创建字段选数据类型参考大全
- mysql数据类型字段插入空字符串自动填充为0报错
- Java和mysql的数据类型对应
- MySQL的数据类型
- 正确利用php向MySQL datetime类型中插入数据
- MySQL入门--mysql字段的数据类型
- mysql字段类型MicrosoftAccess、MySQL以及SQLServer所使用的数据类型