Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/django/22.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python Django/Postgres:在带有条件注释的查询中,是否返回一个带有特定值的ArrayField?_Python_Django_Postgresql - Fatal编程技术网

Python Django/Postgres:在带有条件注释的查询中,是否返回一个带有特定值的ArrayField?

Python Django/Postgres:在带有条件注释的查询中,是否返回一个带有特定值的ArrayField?,python,django,postgresql,Python,Django,Postgresql,我正在使用Python 2.7、Postgres 9.6和Django 1.11。我有一个型号,Person,上面有两个CharFields,director\u id和company\u id。我想根据一个特定的条件对它进行注释:当director\u id不为空时,执行一个子查询,执行ArrayAgg,返回一个与之关联的公司id的数组(很好,已经工作了);如果不是,我希望返回一个长度为1的数组,其中只包含该人员的公司id。有没有一种方法可以指定我希望default返回一个包含特定值的数组 P

我正在使用Python 2.7、Postgres 9.6和Django 1.11。我有一个型号,
Person
,上面有两个
CharField
s,
director\u id
company\u id
。我想根据一个特定的条件对它进行注释:当
director\u id
不为空时,执行一个子查询,执行
ArrayAgg
,返回一个与之关联的
公司id
的数组(很好,已经工作了);如果不是,我希望返回一个长度为1的数组,其中只包含该
人员的
公司id
。有没有一种方法可以指定我希望
default
返回一个包含特定值的数组

Person.objects.annotate(
    aggregated_company_ids=Case(
        When(director_id__isnull=False, then=Subquery(aggregated_company_ids)),
        default=[F("company_id")],  # ProgrammingError: can't adapt type 'F'
        output_field=ArrayField(models.CharField()),
    ),
)
我发现
ArrayAgg(F(“company_id”)
有效,并给了我一个数组,其中只有一个
company_id

Person.objects.annotate(
    aggregated_company_ids=Case(
        When(director_id__isnull=False, then=Subquery(aggregated_company_ids)),
        default=ArrayAgg(F("company_id")),
        output_field=ArrayField(models.CharField()),
    ),
)

不确定这是否是唯一也是最好的解决方案,但这是我找到的唯一解决方案。

我不能很容易地测试这一点,但默认值不如When强大,也许使用另一个When代替默认值可以工作
例如,当(director\u id\u isnull=True,…
时,它不漂亮,但应该这样做。@Oniro感谢您的建议,但我得到了相同的编程错误。我认为问题可能是它没有将
[F(“company\u id”)]
识别为指定我要指定的内容,即在其中包含特定字段值的数组。