mysql中以的类型是以 “ 数据类型(m) ” 来定义的 :

其中 数字m在不同的数据类型中表示含义是不同的。

整型数已经限制了取值范围,比如tinyint占一个字节(8bit)、int占4个字节。

所以整型数后面的m不是表示的数据长度,而是表示数据在显示时显示的最小长度(长度为字符数)。

tinyint(1) 这里的1表示的是最小显示宽度是1个字符。

tinyint(2) 这里的2表示的是最小显示宽度是2字符,但这里光设置m是没有意义的,你还需要指定当数据少于长度m时用什么来填充,比如zerofill(表示有0填充)。

设置tinyint(2) zerofill 你插入1时他会显示01。

设置tinyint(4) zerofill 你插入1时他会显示0001。