mysql tinyint 1 范围_mysql tinyint 取值范围浅析

  • Post author:
  • Post category:mysql


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。

有了以上的介绍,你对mysql的tinyint数据类型是不是了解更多了呢?



版权声明:本文为weixin_42322219原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。