微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用 StringAgg 和另一个函数进行注释时出现 Django 错误

如何解决使用 StringAgg 和另一个函数进行注释时出现 Django 错误

我正在尝试获取与每个用户关联的站点名称的平面列表。结果将写入 CSV 文件

email,sites
a@b.com,site1|site2|site3
b@b.com,site3

StringAgg 用于在注释中展平 siteshas_flagis_admin 都在注释中工作。所有这些字段都适用于 created_date。但是,如果我尝试在 siteshas_flag 中包含 is_admin,则会引发错误 'WhenNode' object has no attribute 'copy'

简化代码

users = (
    account.get_users()
    .annotate(
        is_admin=ExpressionWrapper(Q(role=1),output_field=BooleanField()),has_flag=ExpressionWrapper(Q(thing__isnull=False),output_field=BooleanField(),created_date=Func(F("created_at"),Value("YYYY-MM-DD"),function="to_char",output_field=CharField()),sites=StringAgg('usersite__site__name',delimiter="|"),)
    .values_list(
        "email","is_admin","has_thing","created_date","sites",)
)

class UserSite():
    class Meta(object):
        unique_together = ("user","site")

    user = models.ForeignKey(User,on_delete=models.CASCADE)
    site = models.ForeignKey(Site,on_delete=models.CASCADE)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。