MySQL int 类型的长度和范围解惑

MySQL int 类型的长度和范围解惑,第1张

Mysql 建表过程中:

MySQL中int类型占用4个字节[byte(B)],1B有8个位[bit(b)],一个位(b)就代表一个0或者1,那么MySQL中int占用4B,对应位就是 4*8b = 32b 了,也就是说 int 表示的数字 个数 是: 2的32次方

因为字节分有符号和无符号两种,于是 int 有符号 的 范围就是 -2的31次方 到 2的31次方减去1 [?1 为什么不是32次方?] [?2 为什么要减去1?],即 -2147483648 ~ 2147483647; int 无符号(unsigned) 的 范围就是 0 到 2的32次方减去1。

知道了 int 类型的范围后,我们再来看看长度是什么意思。 在MySQL手册中,字段类型的长度用 “M” 表示,表示最大显示宽度。 int 的 最大有效显示宽度是 255。 注意: 此处表示 显示宽度 和 存储大小或类型及范围 无关

参考:

1、 https://blog.csdn.net/weixin_33695082/article/details/92011222

数值类型包含: int tinyint bigint float decimal

int 大整型(占 4 个字节的存储空间)

tinyint 微小整型(占 1 个字节的存储空间)

bigint 极大整型(占 8 个字节的存储空间)

float 占4个字节,最多显示7个有效位。常用于成绩。

float(5,2)取值范围:

decimal 最多可以显示 28 个有效位

存储空间计算:整数部分和小数部分分开存储,将 9 的倍数包装成 4 个字节,余数占用的字节数如下:

decimal 的整数位和小数位模9的余数和字节对照表

例如: decimal(19,9)

整数部分:

小数部分:

char 定长:当列中存储的字符串达不到最大长度时,使用空格进行补足。

varchar 变长

char 浪费存储空间,但性能高。 varchar 节约存储空间,但存储性能低。

text / longtext(4G)

数值类型宽度为显示宽度,和占用存储空间大小无关;字符类型的宽度,超过则无法存储:

对于枚举类型的字段,字段值只能在列举的范围内选择。

日期时间类型: date time datetime timestamp

date日期:

time时间:

datetime日期时间:

timestamp 日期时间:

日期时间函数: NOW() CURDATE() CURTIME()

NOW() 返回服务器当前的时间:

CURDATE() 返回当前日期:

CURTIME() 返回当前时间:

插入日期时间:

语法格式:

示例:

查询1天以内的记录:

查询2年前至今年的记录:


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

原文地址: http://outofmemory.cn/sjk/9848962.html

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

发表评论

登录后才能评论

评论列表(0条)

保存