mysql int 长度能为20,mysql中int、bigint、smallint 和 tinyint长度分别是多少

本文就mysql中int、bigint、smallint、tinyint的区别作以详细介绍,首先请看各类型对应的数据范围图表。

mysql int 长度能为20,mysql中int、bigint、smallint 和 tinyint长度分别是多少_第1张图片

我们首先做下名词解释

(1)byte  表示字节,二进制数系统中,每个0或1就是一个位(bit),是存储信息的最小单位。

(2)bit 表示位,字节是由8个位所组成,可存储一个字符:字母(A~Z)、数字(0~9)、或符号(,.?!%&+-*/)、以及一些控制信息等。

需要说明的是 1Byte = 8 bit ,一个字节最多可以代表的数据长度是2的8次方 11111111 在计算机中也就是 -128到127。

通常用大写B表示byte即字节,用小写b表示bit即位,一个字节=八个位,即1B=8b

1.BIT[M]

位字段类型,M表示每个值的位数,范围从1到64,如果M被忽略,默认为1

2.TINYINT[(M)] [UNSIGNED] [ZEROFILL]  M默认为4

很小的整数。带符号的范围是-128到127。无符号的范围是0到255。

3. BOOL,BOOLEAN

是TINYINT(1)的同义词。zero值被视为假。非zero值视为真。

4.SMALLINT[(M)] [UNSIGNED] [ZEROFILL] M默认为6

小的整数。带符号的范围是-32768到32767。无符号的范围是0到65535。

5.MEDIUMINT[(M)] [UNSIGNED] [ZEROFILL] M默认为9

中等大小的整数。带符号的范围是-8388608到8388607。无符号的范围是0到16777215。

6. INT[(M)] [UNSIGNED] [ZEROFILL]   M默认为11

普通大小的整数。带符号的范围是-2147483648到2147483647。无符号的范围是0到4294967295。

7.BIGINT[(M)] [UNSIGNED] [ZEROFILL] M默认为20

大整数。带符号的范围是-9223372036854775808到9223372036854775807。无符号的范围是0到18446744073709551615。

需要注意:这里的M代表的并不是存储在数据库中的具体的长度,如果误以为int(3)只能存储3个长度的数字,int(11)就会存储11个长度的数字,这是不对的。

tinyint(1) 和 tinyint(4) 中的1和4并不表示存储长度,只有字段指定zerofill是有用,

如tinyint(4),如果实际值是2,如果列指定了zerofill,查询结果就是0002,左边用0来填充。

你可能感兴趣的:(mysql,int,长度能为20)