• Q查询


    一、Complex lookups with Q objects(Q对象的复杂查询)

    仅仅靠单一的关键字参数查询已经很难满足查询要求。此时Django为我们提供了Q查询:

    class Q

    1、Q对象(django.db.models.Q)可以对关键字参数进行封装,从而更好地应用多个查询,下面是最简单的例子:

    from django.db.models import Q
    from login.models import New  #假设在我的login app的models.py下有New数据类 q1=New.objects.filter(Q(question__startswith='What'))

    2、可以组合使用&,|操作符,当一个操作符是用于两个Q的对象,它产生一个新的Q对象。

    Q(question__startswith='Who') | Q(question__startswith='What')

    3、Q对象可以用~操作符放在前面表示否定,也可允许否定与不否定形式的组合

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

    4、应用范围:

    Each lookup function that takes keyword-arguments (e.g. filter(), exclude(), get()) can also be passed one or more Q objects as positional (not-named) arguments. If you provide multiple Q object arguments to a lookup function, the arguments will be “AND”ed together. For example:

    Poll.objects.get(
        Q(question__startswith='Who'),
        Q(pub_date=date(2005, 5, 2)) | Q(pub_date=date(2005, 5, 6))
    )
    ... roughly translates into the SQL:
    
    SELECT * from polls WHERE question LIKE 'Who%'
        AND (pub_date = '2005-05-02' OR pub_date = '2005-05-06')

    5、Q对象可以与关键字参数查询一起使用,不过一定要把Q对象放在关键字参数查询的前面。

    正确:
    Poll.objects.get(
        Q(pub_date=date(2005, 5, 2)) | Q(pub_date=date(2005, 5, 6)),
        question__startswith='Who')
    错误:
    Poll.objects.get(
        question__startswith='Who',
        Q(pub_date=date(2005, 5, 2)) | Q(pub_date=date(2005, 5, 6)))

     

    6、django使用Q来实现动态可变条件的或查询

     

    #固定条件的或查询

     User.objects.filter(Q(is_staff=True) | Q(username='123'))

    #[<User: staff_a>, <User: 123>, <User: staff_b>]
    #对于动态可变条件的或查询
    di = {'username': '123', 'is_staff': True} # 条件不固定
    q = Q()
    for i in di:
    q.add(Q(**{i: di[i]}), Q.OR)
    #<django.db.models.query_utils.Q object at 0x103a84bd0>
    #<django.db.models.query_utils.Q object at 0x103af1110>
    # print q
    (OR: (AND: ), (AND: ('username', '123')), ('is_staff', True))
    User.objects.filter(q)
    #[<User: staff_a>, <User: 123>, <User: staff_b>]

    小注小注:

    1.django 用Q(a)|Q(b)来实现 sql中 where a or b 功能
    2.Q(Name__contains=sqlstr) 这句的意思是 在 sql 中 like '%sqlstr%'
    3.Q(VIPId__VIPMachineCode__contains=sqlstr) 意思跟上面一样,不过要注意 VIPId 在CarOwner中是一个外键,引用的字段是VIP中的主键
    4.如果filter()函数中有逗号,是代表WHERE AND 的意思

    参考官网:https://docs.djangoproject.com/en/1.5/topics/db/queries/#django.db.models.Q

  • 相关阅读:
    PCB 设计文件中哪些可以不做成元件
    IAR 9+ 编译 TI CC2541 出现 Segment ISTACK (size: 0xc0 align: 0) is too long for segment definition.
    每日一条 git 命令行:git clone https://xxxxx.git -b 12.0 --depth 1
    FastAdmin Bootstrap-table 特定某行背景变红
    如何查看 ThinkPHP5.1 的升级说明
    Windows 2008 关闭远程桌面的单用户多会话模式
    来测试一下你的“金耳朵”
    笔记:关于网站的流量攻击
    排序算法视频 《6 分钟演示 15 种排序算法》
    【转】移动web页面支持弹性滚动的3个方案
  • 原文地址:https://www.cnblogs.com/zknublx/p/5992214.html
Copyright © 2020-2023  润新知