当前位置:Gxlcms > PHP教程 > MySQL有限个数的数据用tinyint存和varchar存哪种更好些?

MySQL有限个数的数据用tinyint存和varchar存哪种更好些?

时间:2021-07-01 10:21:17 帮助过:0人阅读

tinyint服务器判断数字后显示对应的内容
varchar就直接存要显示内容

如存XXX的分类
如存男/女

(新手求解答)

回复内容:

tinyint服务器判断数字后显示对应的内容
varchar就直接存要显示内容

如存XXX的分类
如存男/女

(新手求解答)

按照“规矩”的话数据库设计是应该要符合三个范式的,就是要新建一张专门的表用来存放“类别”。不过实际情况中如果“类别基本没有变动”的话,直接存“要显示的内容”会好一些,这样取数据的时候不需要再查询另一张表,减少一次查询。当然,缺点就是占用的空间大了,但拿空间来换时间是明智的。

就PHP来说,存在数据库中的是数字,取出数字的时候通过一个数组来获取“类别”的名称,也是一种不错的做法。

另外,类别的个数只有少数几个的情况如“男、女”时,直接约定用1表示男,用0表示女也是常见的做法,不过记得给字段加上注释/描述。

最后,提个小细节,长度固定的字符串用char存,相对用varchar存,在读取方面会快些。

使用enum

推荐一下MySQL中的enum,
它表现出来varchar的字符串形式,
但是实际上只占一个tinyint(可能是,我不是很确定。我记得enum好像是占2字节)的空间。

char,这点转换算不了啥。

人气教程排行