首先明确tinyint 不管后面的数字是多少,它存储的范围始终是不变的。
有符号的范围是 -128 到 127。无符号的范围是 0 到 255。
注意数字类型后面括号中的数字,不表示长度,表示的是显示宽度,这点与 varchar、char 后面的数字含义是不同的。
所以TINYINT类型的可以表示为TINYINT(1)也可以表示为TINYINT(3).
cndn上的例子如下:
Table Create Table
------ -------------------------------------------------------
t233 CREATE TABLE `t233` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`str` varchar(255) NOT NULL,
`money` float(12,2) unsigned NOT NULL,
`state` tinyint(1) unsigned zerofill DEFAULT NULL,
`state2` tinyint(2) unsigned zerofill DEFAULT NULL,
`state3` tinyint(3) unsigned zerofill DEFAULT NULL,
`state4` tinyint(4) unsigned zerofill DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=6 DEFAULT CHARSET=utf8
insert into t233 (str,state,state2,state3,state4) values('csdn',4,4,4,4);
select * from t233;
query result(1 records)
id str money state state2 state3 state4
5 csdn 0.00 4 04 004 0004
0 到 255
站位是1字节
有符号的范围是 -128 到 127。无符号的范围是 0 到 255。