一个mysql字段字符长度1000,不需要用于搜索,海量数据,把它设置为varchar好还是text好?

php中文网
发布: 2016-06-06 20:13:02
原创
1877人浏览过

一个mysql字段最大字符长度1000,不需要用于搜索,记录条数可能过千万,将来可能会水平分表,把它设置为varchar好还是text好?需不需要先垂直分表?

回复内容:

一个mysql字段最大字符长度1000,不需要用于搜索,记录条数可能过千万,将来可能会水平分表,把它设置为varchar好还是text好?需不需要先垂直分表?

mysql的记录行长度是有限制的,不是无限长的,这个长度是64K,即65535个字节,对所有的表都是一样的。
MySQL对于变长类型的字段会有1-2个字节来保存字符长度。
当字符数小于等于255时,MySQL只用1个字节来记录,因为2的8次方减1只能存到255。
当字符数多余255时,就得用2个字节来存长度了。
在utf-8状态下的varchar,最大只能到 (65535 - 2) / 3 = 21844 余 1。
在gbk状态下的varchar, 最大只能到 (65535 - 2) / 2 = 32766 余 1

引用:https://ruby-china.org/topics/24920

1000这个长度很常见,大部分时候不需要分表。 也不需要用text。 直接用varchar就好。
在5.5以后的版本的mysql中,varchar不再有字段长度限制。 但是需要注意的是,整行记录有65535字节的限制(是字节,不是字符。如果是UTF-8编码,单个字符可能占用2-3个字节)。

Dora
Dora

创建令人惊叹的3D动画网站,无需编写一行代码。

Dora 547
查看详情 Dora

记录在千万级更是没问题了。 读写十分频繁,性能十分严苛时,才考虑将这个字段分离出去。

VARCHAR() 最大255 只能存 text

一个mysql字段字符长度1000,不需要用于搜索,海量数据,把它设置为varchar好还是text好?

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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