zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    COCO2018 目标检测
    最小生成树[摘录自严长生老师的网站]
    PANet训练自己的数据(VIA标注)
    图的遍历[摘录自严长生老师的网站]
    图的链式存储(邻接表)【摘录自严长生老师的网站】
    Android写入到mysql里的中文总是乱码?
    Mac 当xampp里mysql无法启动的解决办法
    【代码段】Android Studio使用DatePicker选择日期
    Android jdbc连接mysql报错解决方案 (Communications link failure)
    绝命毒师口语精析(4)
  • 原文地址:https://www.cnblogs.com/zknublx/p/5992214.html
Copyright © 2011-2022 走看看