首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Django中存储5分刻度的最有效方法

在Django中存储5分刻度的最有效方法
EN

Stack Overflow用户
提问于 2014-08-23 10:32:38
回答 1查看 101关注 0票数 1

我有一首歌的模型如下:

代码语言:javascript
复制
class Song(models.Model):
    name = models.CharField(max_length=255)
    artist = models.CharField(max_length=255)
    rating = models.SmallIntegerField()

我想知道是否有更好的方法来存储一首歌的评级,因为它是一个从1到5的等级?从更好的意义上说,在数据库中存储相同的数据将占用更少的空间。

我已经阅读了Django文档,SmallIntegerField看起来是最小的值字段。

但是它可以保存从"-32768到32767“不等的值,这对于我的需要来说是过分的,因为我只想存储5个唯一的值(1到5)。

有较小的字段类型吗?我应该使用CharField(max_length=1)吗?

有什么建议吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-08-23 12:26:07

您可以使用一个更小的PositiveSmallIntegerField,它保证在所有数据库中存储从0到32,767之间的所有整数(即符号空头的正范围)。

存储优化的理想解决方案是使用类似于位场的方法,您可以在其中以二进制形式存储分数,但是在表示数值的内置Django中没有类似的字段类型。您必须创建自己的字段,存储一个3位的无符号整数,并包含将其粘合到Django的ORM中所需的所有适当开发。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25460981

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档