tinyint 范围 mysql_mysql中TINYINT的取值范围

tinyint 范围 mysql_mysql中TINYINT的取值范围在 MySQL 的数据类型中 Tinyint 的取值范围是 带符号的范围是 128 到 127 无符号的范围是 0 到 255 见官方 MySQL5 1 参考手册 http dev mysql com doc refman 5 1 zh column types html numeric types Tinyint 占用 1 字节的存储空间 即 8 位 bit 那么 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,,换算成十进制就是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的取值范围

本文地址: http://www.cppcns.com/shujuku/mysql/111843.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/219859.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月17日 下午9:44
下一篇 2026年3月17日 下午9:44


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号