MySQL字段设计规范避免使用TEXT/BLOB数据类型(坑)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL字段设计规范避免使用TEXT/BLOB数据类型(坑)相关的知识,希望对你有一定的参考价值。

一、说明
假期有时间可以多去看看一些表的设计,发现了不少问题,老系统上过百的字段,里面含有大量的mediumtext,不到500万的数据量,开发规范中有要求表设计不要超过500万数据量。查看了表占用的磁盘空间120G,毫无疑问是大表,当初设计的时候就没有考虑过设计。一句话上线能用就行,管他呢。

二、mysql规范
1、单表不要超过500万条记录,同时评估单表所占用磁盘空间不要超过50G,否则考虑优化、分表等。
2、禁用text字段类型,如果必须的用,也需要单独设计表。

三、禁用text字段类型原因
1、性能很差,排序等操作时,就不能使用内存临时表,必须使用磁盘临时表进行。
2、TEXT或BLOB类型只能使用前缀索引,MySQL对索引字段长度是有限制的。

四、解决办法
定好规范,严格执行(执行很难),一两个DBA面对几十上百的业务系统,几万个表,上百万的字段通过每一个表和字段人工审核是不可能完成的,最终还是要靠智能化的审核系统!

以上是关于MySQL字段设计规范避免使用TEXT/BLOB数据类型(坑)的主要内容,如果未能解决你的问题,请参考以下文章

MySQL 设计规范(续)

mysql设计规范

A.004.14.Mysql开发设计最佳规范

mysql设计规范

mysql 注意点

MySQL使用记录