首页 > 跟同事理论:这个mysql 字段用什么好?

跟同事理论:这个mysql 字段用什么好?

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

大家觉得如何?


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

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

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

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

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


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


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


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


经验之谈是

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

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

【热门文章】
【热门文章】