0

0

mysql数据库中的数据类型选择与存储效率

P粉602998670

P粉602998670

发布时间:2026-02-16 09:19:02

|

988人浏览过

|

来源于php中文网

原创

用tinyint unsigned代替int存布尔值或状态码可省3字节/行,因其仅占1字节且支持0–255范围;varchar长度应按实际业务需求设定,避免过大导致内存浪费和性能下降;datetime占8字节、timestamp占4字节且有时区自动转换;json类型查询性能差、难索引,应优先规范建表。

mysql数据库中的数据类型选择与存储效率

TINYINT 代替 INT 存布尔值或状态码能省 3 字节/行

MySQL 中 INT 固定占 4 字节,而 TINYINT 仅占 1 字节。如果你存的是开关(0/1)、订单状态(1=待支付、2=已发货、3=已完成)这类取值范围在 0–255 的整数,TINYINT UNSIGNED 是更紧凑的选择。误用 INT 不仅浪费磁盘空间,在大表(千万级行)中还会显著增加 Buffer Pool 压力和查询扫描开销。

注意点:

  • TINYINT 默认有符号,范围是 −128 到 127;如需 0–255,必须显式声明 TINYINT UNSIGNED
  • ORM 框架(如 Django、Laravel Eloquent)可能默认映射布尔字段为 TINYINT(1),但 TINYINT(1)(1) 仅影响显示宽度,不约束取值范围或存储大小
  • 不要因为“以后可能扩展”提前用大类型——类型升级代价远高于初期设计成本

VARCHAR 长度设太大会拖慢排序和临时表性能

MySQL 在执行 ORDER BYGROUP BY 或创建内部临时表时,若字段是 VARCHAR(1024),即使实际只存 10 个字符,也会按最大长度预分配内存。尤其当该字段参与索引或作为 JOIN 条件时,可能导致临时表从内存转到磁盘(Using temporary; Using filesort)。

实操建议:

瑞宝通JAVA版B2B电子商务系统
瑞宝通JAVA版B2B电子商务系统

瑞宝通B2B系统使用当前流行的JAVA语言开发,以MySQL为数据库,采用B/S J2EE架构。融入了模型化、模板、缓存、AJAX、SEO等前沿技术。与同类产品相比,系统功能更加强大、使用更加简单、运行更加稳 定、安全性更强,效率更高,用户体验更好。系统开源发布,便于二次开发、功能整合、个性修改。 由于使用了JAVA开发语言,无论是在Linux/Unix,还是在Windows服务器上,均能良好运行

下载
  • 根据业务确定最大长度:用户名通常 VARCHAR(32) 足够,邮箱用 VARCHAR(255)(符合 RFC 标准上限),别直接写 VARCHAR(1024)
  • UTF8MB4 下,每个字符最多占 4 字节,所以 VARCHAR(255) 实际可能占用 1020 字节 —— 这会影响单页存储行数,间接影响 B+ 树深度
  • 如果字段内容长度非常固定(如身份证号、UUID),优先考虑 CHAR,避免变长开销

DATETIMETIMESTAMP 不只是时区差异,还涉及存储空间与自动行为

DATETIME 占 8 字节,范围是 1000–9999 年;TIMESTAMP 只占 4 字节,范围是 1970–2038 年(UNIX 时间戳限制),且会自动转换时区。选错不仅浪费空间,还可能引发隐式行为问题。

关键区别:

  • TIMESTAMP 列默认开启 ON UPDATE CURRENT_TIMESTAMP,而 DATETIME 不会,除非显式声明
  • 如果应用层已统一处理时区(比如全用 UTC 存储),用 DATETIME 更可控;若依赖 MySQL 自动转时区,才考虑 TIMESTAMP
  • MySQL 5.6.4+ 支持 DATETIME(3) 等微秒精度,但会额外增加 1–3 字节;TIMESTAMP(3) 同理,需权衡精度是否真有必要

JSON 字段不是万能的,JSON 类型比等效的规范表结构慢且难索引

MySQL 5.7+ 支持原生 JSON 类型,但它本质是经过验证的长文本(内部以二进制格式存储),查询时仍需解析。相比拆成独立字段,它在过滤、排序、连接场景下性能明显下降。

典型陷阱:

  • WHERE JSON_CONTAINS(json_col, '"active"', '$.status') 无法使用普通索引,必须建生成列 + 索引才能加速
  • 频繁更新 JSON 中某个键值,会导致整条记录重写,加剧 MVCC 版本链和 undo log 压力
  • 备份、复制、审计工具对 JSON 内容支持不一,某些监控系统甚至无法提取字段级统计
ALTER TABLE users ADD status TINYINT UNSIGNED AS (json_unquote(json_extract(profile, '$.status'))) STORED;
CREATE INDEX idx_status ON users(status);
索引生成列虽可补救,但终究是绕过范式的设计。真正需要灵活 schema 的场景,不如交给 MongoDB 或外部配置服务,别强塞进 MySQL。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

332

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

285

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

581

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

379

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

131

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

78

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

69

2025.08.05

mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

678

2023.06.20

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

145

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.2万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 833人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号