3

我需要配置一个django.contrib.postgres.fields.ArrayField对列表,其中第一个元素是浮点数,第二个元素是一个小的正整数:

data = [[1.23, 3], [2.42, 1], [3.72, 29]]

我怎么能这样做?可能吗?我尝试了这样的事情,但没有奏效:

class MyModel(models.Model):
    my_field = ArrayField(
                   models.FloatField(default=0),                        
                   models.PositiveSmallIntegerField(default=0),
                   null=True
               )
4

2 回答 2

4

我只想知道我是否可以在 ArrayField 中使用不同的字段类型。

不,这是不可能的,它将涉及一种非常混乱的方式将数据从数据库中取出,并且无法真正将数据库中的字段类型设置为具体类型。

相反,只需使用两个浮点字段

my_field = ArrayField(
    ArrayField(
        models.FloatField(default=0),
        size=2,
    )
)
于 2017-02-03T10:08:03.527 回答
1

如果你真的需要这个功能,你可以试试JSONField

class MyModel(models.Model):
    my_field = JSONField()

并存储'[[1.23, 3], [2.42, 1], [3.72, 29]]'在其中,尽管它确实会引发有关数据模型设计的问题。

于 2019-10-03T16:00:22.973 回答