跟同事理论:这个mysql 字段用什么好?
怪我咯
怪我咯 2017-04-17 14:48:49
[MySQL讨论组]

一个数组序列化,大概长度不到一百,偶尔有200吧,不过很少几乎没,然后 同事用了char类型,然后用255个字节, 他说 速度快
我觉得 这个表有其他类型 包括文本,时间,int等,作为一个表已经不是静态表了,动态表char类型速度是没区别的!所以我觉得用varchar 类型 255比较合适~ 节省点字节,现在数据库已经99M了 我擦~~

大家觉得如何?

怪我咯
怪我咯

走同样的路,发现不同的人生

全部回复(5)
ringa_lee

这个用哪个影响都不会太大。

char占用固定长度,在MyISAM引擎中,数据的物理结构上会连续一点,速度在某些场景下是会快一点,产生碎片会少一点。典型的空间换时间。

在InnoDB引擎中,影响不会太大,没什么好争论的。

现在MyISAM引擎基本没人使用了,InnoDB上char类型的使用会浪费更多的内存池空间。

经验之谈。InnoDB引擎如果是固定长度的就用char,比如32位md5的值存储就用char(32)
基他用varchar。

迷茫

经验之谈是

相对固定长度的字符一般用char,比如这个列绝大部分都是在200,有198,197的这种
非固定长度,并且跨度较大的,会用varchar,比如一部分是200,还有一部分是2的这种

char一般会在效率等方面比varchar好一些

天蓬老师

要知道char是固定长度,有多余的以空格填充,速度自然比varchar快,要说到字节,varchar对英文与汉字都是2个字节,而char对英文一个字节,汉字两个字节。当然char类型对数据的处理相对来说也要使用trim来消除空格。所以到底要使用什么还是要看你真正要追求的是什么。

巴扎黑

速度快?网上看的?自己试验过?不想呵呵了,固定短字符用char,其他用varchar

高洛峰

用测试数据说话。跑个1个G数据写入查询更新,试试就知道了

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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