gpt4 book ai didi

mysql - Django:空日期字符串应该返回全部

转载 作者:行者123 更新时间:2023-11-29 19:02:35 25 4
gpt4 key购买 nike

所以,我有一个来自输入字段的日期和一个到输入字段的日期。当我传入日期范围从 到 时,它工作正常。但是,当我尝试将其中一项或两项留空以获取所有项目或部分项目时,当我尝试设置默认的空字符串时,它会出现 ValueError: Cannot use None as a query value 或格式错误。

def report(self, request):
date_from = query['date_from'] if query['date_from'] else None
date_to = query['date_to'] if query['date_to'] else None

queryset = Client.objects.filter(
client_code__in=clients,
account__note__creation_time__gte=date_from,
account__note__creation_time__lte=date_to,
)

为了提供更好的上下文,如果我将两个字段留空,我应该获取从开始到现在的所有项目,如果我填写字段中的日期但将日期留空,我应该获取从日期到现在的所有项目。如果我有从现场购买空日期的日期,我应该从开始到日期获得元素。

我很懒,找到了一个可行的解决方案,但对此不太满意。如果有人发现更好的东西,请随时分享。

query = Q()
if clients:
clients = clients.split(',')
query &= Q(client_code__in=clients)
if date_from:
query &= Q(account__note__creation_time__gte=date_from)
if date_to:
query &= Q(account__note__creation_time__lte=date_to)

Client.objects.filter(query)

最佳答案

如果你在查询集上放置一个过滤器,你必须为该过滤器提供有效的值。Django 无法猜测你实际上并不想要该过滤器......

但是有一些方法可以让它看起来更好一点,例如:

qs = Client.objects.all()

if date_from:
qs = qs.filter(account__note__creation_time__gte=date_from)
if date_to:
qs = qs.filter(account__note__creation_time__lte=date_to)

# etc etc for all your AND queries.
# but for OR type queries you need to use Q objects.

当您创建查询集时,就像我使用 Client.objects.all 所做的那样,它实际上并不会立即访问数据库并获取对象。因此,您可以通过添加其他过滤器来修改该查询集以限制您的结果。您可以使用所有不同的查询集方法...例如 order_by()fetch_lated() 等...直到查询集符合您的要求。在您尝试通过迭代查询集来读取对象之前,它实际上不会执行任何 SQL,例如:

# now it will go to the database and get the objects based on your filters.
for instance in qs:
print instance

因此,您会看到,在这种情况下,所有过滤器都在缩小搜索范围(它们全部通过 AND 组合在一起),无需使用 Q(),这样可以减少输入次数并让代码更清晰。但是,如果您正在执行使用 OR 逻辑的查询,或者您可能将相同的查询应用于多个查询集,那么您确实需要使用 Q 类来形成该查询。

关于mysql - Django:空日期字符串应该返回全部,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43742550/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com