MySQL 中int 型最大为255,那么就能储存2的255次方的数字,请问这个2的255次方是怎

MySQL 中int 型最大为255,那么就能储存2的255次方的数字,请问这个2的255次方是怎,第1张

数据存储在计算机中都是以2进制存贮的。

一个字节有8位

1 byte = 1字节 = 8bit 可表达 2的八次方个数字,最大值也就是2的八次方,256。

存储格式 XXXXXXXX

1 short= 2字节 = 16bit 可表达2的十六次方个数字,最大值也就是2的十六次方,65535

存储格式 XXXXXXXX XXXXXXXX

1 int (32) = 4字节 = 32bit 可表达2的32次方,最大值也就是2的32次方。4294967296

存储格式 XXXXXXXX XXXXXXXX XXXXXXXX XXXXXXXX

现在假如你定义了一个byte类型的数 A=1;(最大值为256)

它的存储内容为 0 0 0 0 0 0 1 0(二进制). 共八位 bit。 最大值为1 1 1 1 1 1 1 1(二进制) 换算为十进制:256.

现在 int 类型 255. 1 int(255) =32字节 =256位。 (溢出,所以减一。) 你可以这么理解,它有255位bit。可以储存的最大值为2的255次方。

MYSQL没有这样的功能,自增只能每次增加1,我们只可以控制初值为多少,无法指定增长规律。

但是你的这个需求比较特殊,你可以使用系统功能产生一个1、2、3....这有点自增列(例如id),你需要列值实际上是一个计算字段(2^(id-1)):2的id-1次方

MYSQL可以使用移位运算,例如:

SELECT id,2<<(id-1) FROM tab


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7464300.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-06
下一篇 2023-04-06

发表评论

登录后才能评论

评论列表(0条)

保存