search

Home  >  Q&A  >  body text

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

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

如存XXX的分类
如存男/女

(新手求解答)

PHP中文网PHP中文网2816 days ago571

reply all(4)I'll reply

  • 天蓬老师

    天蓬老师2017-04-10 14:40:40

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

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

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

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

    reply
    0
  • PHPz

    PHPz2017-04-10 14:40:40

    使用enum

    reply
    0
  • 迷茫

    迷茫2017-04-10 14:40:40

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

    reply
    0
  • 天蓬老师

    天蓬老师2017-04-10 14:40:40

    char,这点转换算不了啥。

    reply
    0
  • Cancelreply