tinyint对应什么数据类型?
tinyint类型
tinyint类型代表一个字节,如果一个数字大小超过一个字节,则无法保存。
tinyint有两种类型,第一种(默认)可以储存正负数;第二种指定字段unsigned,只能储存正数。
(1) . 第一种储存过程:一个字节共有8位,将第一个字节作为正负标志,不做数据储存,其中第一个字节为1=负,0=正。所以最大负数=11111111=-127(将后面7位转为十进制制),最大正数=01111111=127;官方给出的tinyint取值范围是-128到127,为什么不是-127到127呢,原因在于当10000000时候,此时为-0,当00000000时,此时为 0,这就出现了两个0,而-0没有意义,所以就规定-0时候,储存数字为-128。这样tinyint最大负数=-128
(2). 第二种储存过程:只存正数,则一个字节最大可以储存1111111=255,即tinyint范围=0~255
tinyint类型数据存储范围?
Tinyint占用1字节的存储空间,即8位(bit)。那么Tinyint的取值范围怎么来的呢?我们先看无符号的情况。无符号的最小值即全部8位(bit)都为0,换算成十进制就是0,所以无符号的Tinyint的最小值为0.无符号的最大值即全部8bit都为1,11111111,换算成十进制就是255.这很好理解。
有符号的Tinyint的取值范围是怎么来的呢?在计算机中,用最高位表示符号。0表示正,1表示负,剩下的表示数值。那么有符号的8bit的最小值就是
1 1 1 1 1 1 1 1=-127
表示负值
最大值:
0 1 1 1 1 1 1 1= 127
表示正值
怎么有符号的最小值是-127,而不是-128呢?这就是本文要说的关键地方了,在计算机中,表示负值是用补码
为什么有符号的TINYINT的最小值是-128?虽然“-0”也是“0”,但根据正、反、补码体系,“-0”的补码和“ 0”是不同的,这样就出现两个补码代表一个数值的情况。为了将补码与数字一一对应,所以人为规定“0”一律用“ 0”代表。同时为了充分利用资源,就将原来本应该表示“-0”的补码规定为代表-128。