python - 使用 StringAgg 和另一个函数进行注释时出现 Django 错误
问题描述
我正在尝试获取与每个用户关联的站点名称的平面列表。结果将写入 CSV 文件:
email,sites
a@b.com,site1|site2|site3
b@b.com,site3
StringAgg 用于sites
在注释中展平。两者都在注释中工作has_flag
。is_admin
所有这些字段都与created_date
. 但是,如果我尝试包含sites
其中一个has_flag
or 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)
解决方案
推荐阅读
- excel - 从 Excel 中的 VBA 返回 Outlook 发件人地址
- string - 当给定非 ASCII 字符或字符串作为参数时,Powershell 的 -gt 和 -lt 究竟表现如何?
- java - 多部分文件在 RestTemplate 中失败 - 错误请求 400 没有正文
- python - 如何从 Common Crawl 获取网页文本?
- python - 如何使用 django pytest 连接到主数据库
- android - 带有应用程序包的Android原始目录abi限定符?
- java - 为什么我的 API 仍然需要身份验证?
- r - 在 r 中找不到“RI”对象
- awk - 为两个文本文件中的多行扩展 awk 脚本,而不是如果两个文件只有一条记录
- java - 可以使用代理卷曲容器内的外部服务,但不能从 java / spring boot 请求(超时503)