跳到主要内容
极客日志极客日志
首页博客AI提示词GitHub精选代理工具
|注册
博客列表

目录

  1. 一、数据类型分类
  2. 二、数值类型
  3. 三、Float 类型
  4. 四、Decimal 类型
  5. 五、Char 类型
  6. 六、Varchar 类型
  7. 七、日期和时间类型
  8. 八、枚举 Enum 和 Set 集合
  9. 1)按条件来查找信息
SQL

MySQL 数据库常见数据类型详解与选型建议

本文介绍了 MySQL 数据库中的主要数据类型分类,包括数值类型(bit、float、decimal)、字符串类型(char、varchar)、日期时间类型以及枚举和集合类型。详细说明了各类型的定义、存储范围、空间占用及适用场景,并给出了精度要求高时使用 decimal、定长数据使用 char 等选型建议。

NodeJser发布于 2026/3/29更新于 2026/4/131 浏览
MySQL 数据库常见数据类型详解与选型建议

一、数据类型分类

https://qiniu.meowparty.cn/coder.2023/2026-03-29/8937bf81441143ba9234540b8b0c0869.gif

二、数值类型

https://qiniu.meowparty.cn/coder.2023/2026-03-29/df740b848120417295ef5d7abe2f7c9f.png

注意:bit 类型:

https://qiniu.meowparty.cn/coder.2023/2026-03-29/7099d41495da4580803a82abe111c8a0.png

三、Float 类型

float(m, d)[unsigned]:M 指定显示长度,d 指定小数位数,占用空间 4 个字节。

小数:float(4,2) 表示的范围是 -99.99~99.99,MySQL 在保存值时会进行四舍五入。

https://qiniu.meowparty.cn/coder.2023/2026-03-29/4af0e1a348e9461bb92096606794a6a2.png

https://qiniu.meowparty.cn/coder.2023/2026-03-29/27e6404c0bec4258b79bdd332f372f8e.png

四、Decimal 类型

decimal(m, d)[unsigned]:定点数 m 指定长度,d 表示小数点的位数。

decimal(5,2) 表示的范围是 -999.99999.99 decimal(5,2) unsigned 表示的范围 0999.99 decimal 和 float 很像,但是有区别:float 和 decimal 表示的精度不一样

极客日志微信公众号二维码

微信扫一扫,关注极客日志

微信公众号「极客日志」,在微信中扫描左侧二维码关注。展示文案:极客日志 zeeklog

更多推荐文章

查看全部
  • FPGA 时钟约束详解:create_clock 与 create_generated_clock
  • Clawdbot 基于 Ubuntu 的通用部署与配置指南
  • AI 与 RPA 融合:如何颠覆传统数据采集流程?
  • JDK 17 下载、安装与环境变量配置指南
  • C/C++ 经典笔试编程题解析与代码实现
  • llama.cpp 多环境部署指南:从 CPU 到 CUDA/Metal 的高效推理实践
  • AI 绘画低成本离线部署方案实战评测

相关免费在线工具

  • SQL 美化和格式化

    在线格式化和美化您的 SQL 查询(它支持各种 SQL 方言)。 在线工具,SQL 美化和格式化在线工具,online

  • SQL 转 CSV/JSON/XML

    解析 INSERT 等受限 SQL,导出为 CSV、JSON、XML、YAML、HTML 表格(见页内语法说明)。 在线工具,SQL 转 CSV/JSON/XML在线工具,online

  • CSV 工具包

    CSV 与 JSON/XML/HTML/TSV/SQL 等互转,单页多 Tab。 在线工具,CSV 工具包在线工具,online

  • Base64 字符串编码/解码

    将字符串编码和解码为其 Base64 格式表示形式即可。 在线工具,Base64 字符串编码/解码在线工具,online

  • Base64 文件转换器

    将字符串、文件或图像转换为其 Base64 表示形式。 在线工具,Base64 文件转换器在线工具,online

  • Markdown 转 HTML

    将 Markdown(GFM)转为 HTML 片段,浏览器内 marked 解析;与 HTML 转 Markdown 互为补充。 在线工具,Markdown 转 HTML在线工具,online

说明:float 表示的精度大约是 7 位。 decimal 整数最大位数 m 为 65。支持小数最大位数 d 是 30。如果 d 被省略,默认为 0,如果 m 被省略,默认是 10。

建议:如果希望小数的精度高,推荐使用 decimal。

五、Char 类型

char(L):固定长度字符串,L 是可以存储的长度,单位为字符,最大长度值可以为 255

https://qiniu.meowparty.cn/coder.2023/2026-03-29/43eebfac2be24145ab8530e15a84de03.png

https://qiniu.meowparty.cn/coder.2023/2026-03-29/f38862e069b6437ba0932c5ec71255a1.png

六、Varchar 类型

varchar(L):可变长度字符串,L 表示字符长度,最大长度 65535 个字节。

关于 varchar(len),len 到底是多大,这个 len 值,和表的编码密切相关:

varchar 长度可以指定为 0 到 65535 之间的值,但是有 1-3 个字节用于记录数据大小,所以说有效字节数是 65532。

当我们的表的编码是 utf8 时,varchar(n) 的参数 n 最大值是 65532/3=21844(因为 utf8 中,一个字符占用 3 字节),如果编码是 gbk,varchar(n) 的参数 n 最大是 65532/2=32766(因为 gbk 中,一个字符占用 2 字节)。

char 和 varchar 比较:

https://qiniu.meowparty.cn/coder.2023/2026-03-29/980fc17e2b34438e9fac3663b89b8b77.png

如果数据确定长度都一样,就使用定长(char),比如:身份证,手机号,md5

如果数据长度有变化,就使用变长 (varchar),比如:名字,地址,但是你要保证最长的能存的进去。

定长的磁盘空间比较浪费,但是效率高。

变长的磁盘空间比较节省,但是效率低。

定长的意义是,直接开辟好对应的空间。

变长的意义是,在不超过自定义范围的情况下,用多少,开辟多少。

七、日期和时间类型

date:日期'yyyy-mm-dd',占用三字节 datetime 时间日期格式'yyyy-mm-dd HH:ii:ss'表示范围从 1000 到 9999,占用八字节 timestamp:时间戳,从 1970 年开始的 yyyy-mm-dd HH:ii:ss 格式和 datetime 完全一致,占用四字节

https://qiniu.meowparty.cn/coder.2023/2026-03-29/3bebeb3637d445058a8a400769b1849e.png

1)更改表中变量的值

https://qiniu.meowparty.cn/coder.2023/2026-03-29/3110653478f1488b88efc1de16805131.png

八、枚举 Enum 和 Set 集合

enum:枚举,'单选'类型;

enum('选项 1','选项 2','选项 3');

该设定只是提供了若干个选项的值,最终一个单元格中,实际只存储了其中一个值;而且出于效率考虑,这些值实际存储的是'数字',因为这些选项的每个选项值依次对应如下数字:1,2,3,…….最多 65535 个;当我们添加枚举值时,也可以添加对应的数字编号。

set:集合,'多选'类型;set('选项值 1','选项值 2','选项值 3');

该设定只是提供了若干个选项的值,最终一个单元格中,设计可存储了其中任意多个值;而且出于效率考虑,这些值实际存储的是'数字',因为这些选项的每个选项值依次对应如下数字:1,2,4,8,16,32,……最多 64 个。

说明:不建议在添加枚举值,集合值的时候采用数字的方式,因为不利于阅读。

https://qiniu.meowparty.cn/coder.2023/2026-03-29/b3f73dadfabf4b3db6fd69cc6d9042ea.png

https://qiniu.meowparty.cn/coder.2023/2026-03-29/d328c422938a4c43a14f6a01894a5afd.png

1)按条件来查找信息

https://qiniu.meowparty.cn/coder.2023/2026-03-29/bb00f3b0759b49618b7278dd4d35fa78.png

https://qiniu.meowparty.cn/coder.2023/2026-03-29/682b0eab45a84eff9ce844432f31afbb.png

ops-nn 自定义算子开发全流程:注册与测试
  • LLaMA-Factory 合并 LoRA 适配器完整指南
  • 人脸识别核心算法:FaceNet 与 ArcFace 原理及实战
  • Nginx 是什么:核心定位、使用场景与配置详解
  • 异步消息队列设计与 Rust 实战集成
  • AI+AR智能眼镜年终盘点:巨头入场驱动产业提速,规模化拐点加速来临!
  • 7 款最佳开源 LLM WebUI 工具推荐
  • OpenClaw 多 Agent 与多飞书机器人配置指南
  • MIT 电机模式控制原理及参数调试
  • 2026 年 3 月 8 日 AI 前沿技术简报
  • SteamVR Unity插件终极指南:从零打造沉浸式VR体验
  • 深入理解 C++ 异常机制
  • 动态规划之完全背包问题详解