MySQL中Tinyint的取值范围

作者:indian

版本:v1.1

修订:2012年11月11日11:01:09

出处:http://indian.blog.163.com/blog/static/108815820056403180/

版权:作者保留对本文的一切修改、发布等权力。任何人想要转载本文部分或全部内容时,必须保留包括作者、版本、修订、出处、版权,共五项信息。对本文的参考引用,则不受限制。

勘正:如有缪误的地方,包括错别字,请联系我修订。Email:[email protected]

 

关键词:数据库,mysql,tinyint

 

 

在mysql的数据类型中,tinyint的取值范围是:带符号的范围是-128到127。无符号的范围是0到255(见官方《mysql 5.1参考手册》http://dev.mysql.com/doc/refman/5.1/zh/column-types.html#numeric-types)。

 

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呢?这就是本文要说的关键地方了,在计算机中,表示负值是用补码(正码、反码、补码的概念见http://indian.blog.163.com/blog/static/1088158200610942745817/)

 

为什么有符号的tinyint的最小值是-128?虽然“-0”也是“0”,但根据正、反、补码体系,“-0”的补码和“+0”是不同的,这样就出现两个补码代表一个数值的情况。为了将补码与数字一一对应,所以人为规定“0”一律用“+0”代表。同时为了充分利用资源,就将原来本应该表示“-0”的补码规定为代表-128。

 

 

~全文完~

 

        indian

    2005年7月4日12:03:18 初稿。v1.0,发表。

    2012年11月11日11:01:09 修订。v1.1,排版美化,加入版权声明。

你可能感兴趣的:(mysql,取值范围,tinyint)