Django运算表达式与Q对象/F对象】的更多相关文章

Django运算表达式与Q对象/F对象 1 模型查询 概述: 1 查询集:表示从数据库中获取的对象的集合 2 查询集可以有多个过滤器,通过 逻辑运算符连接 3 过滤器就是一个函数,基于所给的参数限制查询的结果,类似MySQL模糊查询中where语句 4 查询集等同select语句 2 查询集 特点: 1 查询集通过调用过滤器方进行查询, 查询集经过过滤器筛选后返回新的查询集,可以链式调用 2 惰性执行 创建查询集不会带来任何数据库的访问直到调用数据库才会访问 返回单个数据查询: get() 返回…
在Django的模型中F对象与Q对象比较常用的,所以单独说一下: F对象 F对象位于django.dc.models模板下,使用的时候记得首先导入!!! 作用:F对象主要用于当模型的字段A与字段B进行比较的时候,如果A写在了等号的左边,则B 出现在等号的右边,通过F对象进行构造,用于两个列的比较.举个例子: 假设有数据模型类BookInfo,BookInfo中有属性read和commet,我们要找到阅读量(read)比评论量(commet)多的图书 BookInfo.objects.filter…
今天不巧就用上了. 就是将数据库的字段,自增1的场景. from django.db.models import F DeployPool.objects.filter(name=deployversion_id).update(deploy_no=F('deploy_no')+1) 详细参考网页: http://blog.csdn.net/orangleliu/article/details/40431839 django-orm中F对象的使用 前言 django文档中有一节是 Query-r…
1.关联关系映射及查询1.1django默认开启延迟加载所有多对1和1对1如果不使用select_related(),需要会延迟加载获取到相关对象,因为延迟可能会造成n+1次查询的问题,所以便有了select_related()进行急迫抓取:1.2django默认不会去取多对多的的多方,除非使用prefetch_related('roles'), [User的class中申明 roles = models.ManyToManyField("Role") ]1.3django不需要配置1…
一.F对象 一个F对象代表数据库中某条记录的字段的信息 作用 通常是对数据库中的字段值在不获取的情况下进行操作 用于属性(字段)之间的比较   语法: from django.db.models import F F('列名')   示例1: 示例2:     二.Q对象 当在获取查询结果集使用复杂的逻辑或 | .逻辑非~ 等操作时可以借助Q对象进行操作   导包: from django.db.models import Q   例如:想找出定价低于20元 或清华大学出版学的全部图书,可以写成…
概念 class FF()是代表模型字段的值,也就是说对于一些特殊的字段的操作,我们不需要用Python把数据先取到内存中,然后操作,在存储到db中了. 场景 例1:我们有个统计点击量的字段,每次更新的操作其实就是把字段的值加1. 一般我们的做法是把这条记录取出来,把相应字段加+1,然后在save,类似下面的代码: # Tintin filed a news story! reporter = Reporters.objects.get(name='Tintin') reporter.stori…
Q查询——对对象的复杂查询F查询——专门取对象中某列值的操作 Q查询1.Q对象(django.db.models.Q)可以对关键字参数进行封装,从而更好地应用多个查询,例如: from django.db.models import Q from login.models import New #models对象 news=New.objects.filter(Q(question__startswith='What')) 2.可以组合使用&,|操作符,当一个操作符是用于两个Q的对象,它产生一个…
request request属性 属性: django将请求报文中的请求行.头部信息.内容主体封装成 HttpRequest 类中的属性. 除了特殊说明的之外,其他均为只读的. ''' 0.HttpRequest.scheme 表示请求方案的字符串(通常为http或https) 1.HttpRequest.body 返回一个字符串,代表请求报文的主体.在处理非 HTTP 形式的报文时非常有用,例如:二进制图片.XML,Json等. 例如:b'username=alex&password=123…
一.多表的创建 from django.db import models # Create your models here. class Author(models.Model): id = models.AutoField(primary_key=True) name = models.CharField(max_length=32) age = models.IntegerField() au = models.OneToOneField(to='AuthorDetail',to_fiel…
1 聚合和分组 聚合:对一些数据进行整理分析 进而得到结果(mysql中的聚合函数) 1aggregate(*args,**kwargs) : 通过对QuerySet进行计算 ,返回一个聚合值的字典.其中每一个参数都指定一个包含在字典中的返回值.即在查询集上生成聚合 from django.db.models import Avg,Min,Sum,Max # 从整个查询集生成统计值.比如,你想要计算所有在售书籍的平均价钱.django的查询语法提供了一种方式描述所有图书的集合 Book.obje…