MySQL数据类型

本文只是提炼重点。只会说到常用的数据类型。

整数类型

一般整数类型用的都是 int
int 占用 4个字节。一字节 8位,所以 int 总共是 32 位(4 × 8)。

bash 复制代码
比如 1
00000000 00000000 00000000 00000001

有符号数和无符号数的核心区别在于最高位(符号位)的用途。对于有符号数,最高位为 0 表示正数,为 1 表示负数;而无符号数的所有位都用于表示数值大小。

无符号数取值范围 有符号数取值范围
0 ~ 2³²-1 -2³¹ ~ 2³¹-1

定点数类型

DECIMAL(M, D) 存储空间取决于M和D

M表示该小数最多需要的十进制有效数字个数。

D表示该小数的小数点后的十进制数字个数。

DECIMAL(12,2) 为例,它表示该数值总共最多有 12 位有效数字,其中小数点后占 2 位。因此,整数部分最多可以有 10 位(12 - 2)。

bash 复制代码
99 十进制数 需要装进二进制 怎么做?
一个字节能存进去吗?能
一个字节的范围是 0 ~ 255对吧
1111 1111 = 255

我们把小数点前后拆分。9位分为一组。

小数点前面 1 为 一组 ,一共有 1位 需要用一个字节。

小数点后面 01 为 一组 ,一共有 2位 需要用一个字节。

一共存储这个数据需要 两个个字节。

bash 复制代码
那么如果我的数据类型是这样的DECIMAL(12,2)
000000000 0 , 00
    4     1    1
一共六个字节。

DECIMAL 的存储空间按字段定义 DECIMAL(M,D) 来算

字符类型

M 是什么?M是字符数。

一个字节表示一个字符?

还是多个字节 表示一个字符?

中文字符英文字符 如何通过字节表示?

是由字符集决定的,字符集有哪些 UTF-8 GBK等。

VARCHAR(100) 中的 100 = 最多 100 个字符

W = 当前字符集下每个字符最多占多少字节

utf8mb4 字符集 W 为 4

100 x 4 = 400

bash 复制代码
当M×W < 256时,只需要一个字节来表示占用的字节数。
当M×W >= 256且M×W < 65536时,需要两个字节来表示占用的字节数。
  1. 按 utf8mb4 字符集,把 "小王" 编码成字节,实际是 6 字节。
  2. 因为字段定义是 VARCHAR(100) utf8mb4,最大可能 400 字节,所以需要 2 字节记录真实长度。
  3. 最后占用大约是:2 + 6 = 8 字节。

日期类型

MySQL 5.6.4 之后,DATETIME 固定占用 5个字节。
2026-05-17 20:43:41.xxxxxxx

如果采用十进制 装入 二进制的方式。

bash 复制代码
xxxxxx
.123456 秒
= 123456 微秒
= 123 毫秒 + 456 微秒

存储方式采用的是十进制插入二进制的方式。

假如datetime(2) 小数点后面就占用1个字节。

小数点前面就是5个字节。

如果把 2026-05-17 20:43:41.xxxxxxx拆分成年 月 日 来存放的话。也就是十进制存放的话。

2026 2个字节 05 1个字节 ...

不对。为了节省空间,05 通过 101 三个比特位就能表示。

部分 范围 大概要多少 bit
1~12 4 bit 就够
1~31 5 bit 就够
0~23 5 bit 就够
0~59 6 bit 就够
0~59 6 bit 就够

VARCHAR 是"变长字符串":实际字符编码后有多长,就存多少字节,再加长度前缀。
DATETIME 是"固定结构时间":年月日时分秒都有固定范围,所以 MySQL 可以把它们压缩打包到 5 字节里。

二进制类型

CLOB(5000) 5000是字符。

BLOB(5000) 5000是字节。

后续再补充

相关推荐
日取其半万世不竭1 小时前
Supabase 自建:开源的 Firebase 替代品,带数据库的后端服务
数据库·开源
2301_803934611 小时前
html标签怎样划分页面区域_section与div的区别【介绍】
jvm·数据库·python
埃伊蟹黄面1 小时前
MySQL 库的操作
数据库·mysql
埃伊蟹黄面1 小时前
数据库基础认识
数据库
看我干嘛!1 小时前
Redis安装
数据库·redis·缓存
2401_824697662 小时前
如何管理Oracle服务器的内核共享内存_shmmax与shmall计算
jvm·数据库·python
2301_783848652 小时前
mysql数据迁移过程如何降低性能影响_采用增量备份与多线程同步
jvm·数据库·python
【心态好不摆烂】2 小时前
MySQL——表的约束(上)
数据库·mysql
小娄~~2 小时前
IO模型与并发服务器
运维·服务器·数据库