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

1、基础知识

1.1mysql 数字类型种类和存储范围

MySQL支持SQL标准整数类型INTEGER(或INT)和SMALLINT。作为标准的扩展,MySQL还支持整数类型TINYINT,MEDIUMINT和BIGINT。下表显示了每种整数类型所需的存储和范围。

1.2字段长度说明

MySQL 类型关键字后面的括号内指定整数值的显示宽度(例如,INT(10))。该可选显示宽度规定用于显示宽度小于指定的列宽度的值时从左侧填满宽度。显示宽度并不限制可以在列内保存的值的范围,也不限制超过列的指定宽度的值的显示。

2、字段说明

当我们存在字段int(3)时,存储数据2440会保存成功,且会正常显示。即 int(3)和 int(10)可以存储的数据大小是相同,限制范围在int的范围与数字无关。数字只是在需要左侧用零填满时起作用。

3、tips

1、在我们用int类型作为id的主键时,建议选择Unsigned,这样存储的范围可以增加一倍

2、判断可能出现的字段长度 合理选用tinyint smallint mediumint 和 int

数值类型包含: 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/zaji/6181310.html

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

发表评论

登录后才能评论

评论列表(0条)

保存