django-model之Q查询补充
之前我们使用Q查询都是直接将Q对象写死到filter中,例如:
1、查询id大于1并且评论数大于100的书
print(models.Book.objects.filter(Q(nid__gt=1)&Q(commentNum__gt=100)))
2、查询评论数大于100或者阅读数小于200的书
print(models.Book.objects.filter(Q(commentNum__gt=100)|Q(readNum__lt=200)))
Q 对象可以使用& 和| 操作符组合起来。当一个操作符在两个Q 对象上使用时,它产生一个新的Q 对象。
这样的Q对象中的字段参数如nid__gt=1,是写死的,如果字段参数是从列表等取出来的,可以采用以下方法:
#查询"name","age","tel"三个字段中只要有一个字段包含22的所有数据 #导入Q模块
from django.db.models import Q
#生成Q对象
search_condition = Q()
#修改连接关系为or,默认为and
search_condition.connector = "or"
#将三个字段依次拼接成字符串添加到Q对象中,注意这里字段条件就可以为字符串了,注意append传元祖
for field in ["name","age","tel"]:
search_condition.children.append((field + "__contains", 22))
#打印结果
print(model.objects.filter(search_condition))
django-model之Q查询补充的更多相关文章
- Django之model基础(查询补充)
		
学习完简单的单表查询外,是远远不够的,今天我们对查询表记录做一个补充,接下来来看看基于对象的跨表查询.基于双下划线的跨表查询,聚合查询和分组查询,F查询与Q查询. 比如我们有如下一张表,在model中 ...
 - Django orm Q查询补充
		
Q的简单用法 from django.db.models import Q q = Q() q.children.append(("username", "lyj&quo ...
 - django  F与Q查询  事务 only与defer
		
F与Q 查询 class Product(models.Model): name = models.CharField(max_length=32) #都是类实例化出来的对象 price = mode ...
 - django中的Q查询
		
转载于:https://mozillazg.com/2015/11/django-the-power-of-q-objects-and-how-to-use-q-object.html 原文写的很详细 ...
 - Django - CRM项目(2)Q查询(模糊查询)
		
一.CRM项目(2) 利用Q查询中的q对象完成条件筛选功能. 批量删除.公户转私户功能. 新增一张跟进记录表ConsultRecord,迁移数据库并添加测试数据,实现跟进记录列表页面. 客户列表新增跟 ...
 - 67、django之模型层(model)--查询补充及mookie
		
本篇导航: F查询与Q查询 cookie 一.F查询与Q查询 1.以Book表为例 class Book(models.Model) : title = models.CharField(max_le ...
 - django之模型层(model)--查询补充及cookie
		
已经连续写了好几篇django的模型层(model)增删改查的随笔了,没篇大篇幅都是查询相关的操作,可以看出查询在数据的操作中是多么的重要,而本篇最后再补充一点关于关于查询的一些方法,模型层基本的操作 ...
 - python3开发进阶-Django框架中的ORM的常用操作的补充(F查询和Q查询,事务)
		
阅读目录 F查询和Q查询 事务 一.F查询和Q查询 1.F查询 查询前的准备 class Product(models.Model): name = models.CharField(max_leng ...
 - {django模型层(二)多表操作}一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询、分组查询、F查询和Q查询
		
Django基础五之django模型层(二)多表操作 本节目录 一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询.分组查询.F查询和Q查询 六 xxx 七 ...
 
随机推荐
- Java基础摘要(一)
			
三大特性 封装 所谓封装,也就是把客观事物封装成抽象的类,并且类可以把自己的数据和方法只让可信的类或者对象操作,对不可信的进行信息隐藏.封装是面向对象的特征之一,是对象和类概念的主要特性.简单的说,一 ...
 - 闸流管(或双向可控硅) IGBT 应用
			
十条规则规则1. 为了导通闸流管(或双向可控硅),必须有门极电流≧IGT ,直至负载电流达到≧IL .这条件必须满足,并按可能遇到的最低温度考虑.规则2. 要断开(切换)闸流管(或双向可控硅),负载电 ...
 - 【爬虫】beautiful soup笔记(待填坑)
			
Beautiful Soup是一个第三方的网页解析的模块.其遵循的接口为Document Tree,将网页解析成为一个树形结构. 其使用步骤如下: 1.创建对象:根据网页的文档字符串 2.搜索节点:名 ...
 - 一步一步写jQuery插件
			
转载自:http://www.cnblogs.com/joey0210/p/3408349.html 前言 如今做web开发,jquery 几乎是必不可少的,就连vs神器在2010版本开始将Jquer ...
 - CBP是什么?
			
coded_block_pattern 简称CBP,用来反映该宏块编码中残差情况的语法元素.CBP共有6位,其中前面2位代表UV分量,描述如下表所示:后面4位是Y分量,分别代表宏块内的4个8x8子宏 ...
 - macOS 下 Visual Studio Code(VSCODE)安装配置及应用
			
Visual Studio Code 重新定义了 Code 编辑. 在任何操作系统上编辑和调试应用程序内置 Git 支持1000 种以上的扩展免费和开源 为什么使用VSCODE? 我们来看看以下功能: ...
 - Photon Cloud Networking: OnPhotonSerializeView Not Firing
			
Photon Cloud Networking: OnPhotonSerializeView Not Firing http://answers.unity3d.com/questions/31305 ...
 - 旧书重温:0day2【8】狙击windows的异常处理实验
			
现在进入0day2的第六章内容 其中第六章的书本内容我都拍成了图片格式放在了QQ空间中(博客园一张一传,太慢了)http://user.qzone.qq.com/252738331/photo/V10 ...
 - Kali Linux使用Aircrack破解wifi密码(wpa/wpa2)
			
Kali Linux能做很多事,但是它主要以渗透测试及'破解wifi密码'闻名. 如果你使用Macbook 请看 使用macbook破解WPA/WPA2 wifi密码 要求: 安装有Kali Linu ...
 - 剑指Offer面试题:13.合并两个排序的链表
			
一 题目:合并两个排序的链表 题目:输入两个递增排序的链表,合并这两个链表并使新链表中的结点仍然是按照递增排序的.例如输入下图中的链表1和链表2,则合并之后的升序链表如链表3所示. 二 代码实现 te ...