tinyint服务器判断数字后显示对应的内容
varchar就直接存要显示内容
如存XXX的分类
如存男/女
其实可以根据需要在可读性跟高性能(其实微乎其微)做选择,可读性自然是用varchar更好。别人一看你的数据库内容就知道意思了。用tinyint貌似节省存储空间节省内存,其实我个人觉得这点性能的提升压根就不是数据库优化的重点。我肯定是优先选可读性。
按照“规矩”的话数据库设计是应该要符合三个范式的,就是要新建一张专门的表用来存放“类别”。不过实际情况中如果“类别基本没有变动”的话,直接存“要显示的内容”会好一些,这样取数据的时候不需要再查询另一张表,减少一次查询。当然,缺点就是占用的空间大了,但拿空间来换时间是明智的。
就PHP来说,存在数据库中的是数字,取出数字的时候通过一个数组来获取“类别”的名称,也是一种不错的做法。
另外,类别的个数只有少数几个的情况如“男、女”时,直接约定用1表示男,用0表示女也是常见的做法,不过记得给字段加上注释/描述。
最后,提个小细节,长度固定的字符串用char存,相对用varchar存,在读取方面会快些.
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。