【问题标题】:Django queries: how to make contains OR not_contains queriesDjango 查询:如何进行包含 OR not_contains 查询
【发布时间】:2010-02-25 14:35:41
【问题描述】:

我必须进行查询以获取包含“wd2”子字符串或根本不包含“wd”字符串的记录。有什么办法可以做得很好吗?

好像是这样的:

Record.objects.filter( Q(parameter__icontains="wd2") | Q( ## what should be here? ## ) )

【问题讨论】:

    标签: python django


    【解决方案1】:

    来自 django q object documentation:

    您可以通过将 Q 对象与 & 和 | 组合来组合任意复杂度的语句。运算符并使用括号分组。此外,可以使用 ~ 运算符对 Q 对象求反,从而允许结合普通查询和否定 (NOT) 查询的组合查找:

    Q(question__startswith='Who') | ~Q(pub_date__year=2005)
    

    所以我会推荐

    Record.objects.filter( Q(parameter__icontains="wd2") | ~Q(parameter__icontains="wd") )
    

    【讨论】:

    • 哇,不知道 ~ 运算符。非常感谢!
    • 是不是很优雅?我喜欢在更高层次的组合范式中重用低层次的逻辑思想!
    猜你喜欢
    • 2015-05-02
    • 2010-10-18
    • 1970-01-01
    • 2011-06-25
    • 2010-10-20
    • 1970-01-01
    • 2020-10-28
    • 2010-09-26
    • 2019-04-04
    相关资源
    最近更新 更多