MySQL数据类型的问题?

2024-11-27 22:24:43
推荐回答(3个)
回答1:

首先明确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

回答2:

0 到 255
站位是1字节

回答3:

有符号的范围是 -128 到 127。无符号的范围是 0 到 255。