跳到主要内容
极客日志极客日志面向AI+效率的开发者社区
首页博客GitHub 精选镜像工具UI配色美学隐私政策关于联系
搜索内容 / 工具 / 仓库 / 镜像...⌘K搜索
注册
博客列表
SQL

MySQL 数据类型详解与选型最佳实践

MySQL 数据类型涵盖数值、字符串、日期时间及枚举集合等类别。数值类型中 float 精度约 7 位,decimal 适合高精度定点数;字符串 char 为定长,varchar 为变长且受编码影响最大长度;日期时间包括 date、datetime 和 timestamp。选型时需权衡存储空间与查询效率,高精度计算推荐 decimal,固定长度场景推荐 char。

imJackJia发布于 2026/3/27更新于 2026/6/1237 浏览
MySQL 数据类型详解与选型最佳实践

一、数据类型分类

二、数值类型

注意:bit 类型:

三、float 类型

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

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

四、decimal 类型

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

decimal(5,2) 表示的范围是 -999.99~999.99

decimal(5,2)unsigned 表示的范围 0~999.99

decimal 和 float 很像,但是有区别:float 和 decimal 表示的精度不一样

说明:float 表示的精度大约是 7 位。

decimal 整数最大位数 m 为 65。支持小数最大位数 d 是 30。如果 d 被省略,默认为 0,如果 m 被省略,默认是 10。

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

五、char 类型

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

六、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 比较:

如果数据确定长度都一样,就使用定长(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 完全一致,占用四字节

1)更改表中变量的值

八、枚举 enum 和 set 集合

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

enum('选项 1','选项 2','选项 31,…');

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

set:集合,'多选'类型;set('选项值 11','选项值 2','选项值 31,…');

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

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

1)按条件来查找信息

目录

  1. 一、数据类型分类
  2. 二、数值类型
  3. 三、float 类型
  4. 四、decimal 类型
  5. 五、char 类型
  6. 六、varchar 类型
  7. 七、日期和时间类型
  8. 八、枚举 enum 和 set 集合
  9. 1)按条件来查找信息
  • 💰 8折买阿里云服务器限时8折了解详情
  • Magick API 一键接入全球大模型注册送1000万token查看
  • 🤖 一键搭建Deepseek满血版了解详情
  • 一键打造专属AI 智能体了解详情
极客日志微信公众号二维码

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

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

更多推荐文章

查看全部
  • Android 插件化技术:动态创建 Activity 模式详解
  • XGBoost Python 机器学习实战教程与参数详解
  • 时序数据库架构与生态重构:Apache IoTDB 价值解析
  • AI 赋能智慧农业:基于 ViT 的作物病虫害检测系统实践
  • ToDesk、顺网云与海马云部署 DeepSeek 模型对比评测
  • Windows 下配置 Claude Code 依赖 Git Bash 环境
  • 云边端一体化解析:AI 时代基础设施的核心概念与实践
  • Python 语言概述及职场核心应用场景分析
  • NSSCTF Web 安全竞赛解题思路汇总
  • Python 爬虫技术原理与实战应用指南
  • AI 研发提效指南:Copilot 与 Cursor 在敏捷开发中的实战技巧
  • Ubuntu 22.04 安装 NVIDIA RTX PRO 6000 Blackwell 驱动指南
  • FastGPT 集成 MCP 协议构建工具增强型 AI Agent
  • C++ STL 容器详解:map 与 set 原理及实战
  • 联想小新 Air14 R5 5500U 通过 M.2 转 OCuLink 外接 RX580 显卡方案
  • PostgreSQL 高可用实战:主从流复制搭建与配置详解
  • Java 泛型详解:语法、擦除与通配符
  • Python Web 开发实战:基于 Flask + Vue 构建数字孪生平台
  • 基于 AI 大模型与 Playwright 的 Web UI 自动化测试实践
  • Flutter spry 组件适配鸿蒙 HarmonyOS:轻量级 Web 框架与端侧微服务

相关免费在线工具

  • 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