上一篇Django 2.1.7 模型 - 条件查询 F对象 Q对象 聚合查询讲述了关于Django模型的介绍F对象、Q对象、聚合查询等功能。...不管什么查询,返回的结果都基本是查询集QuerySet,如下: In [16]: MiddlewareInfo.objects.all() Out[16]: QuerySet [查询集中,缓存为空,首次对查询集求值时,会发生数据库查询,django会将查询的结果存在查询集的缓存中,并返回请求的结果,接下来对查询集求值将重用缓存中的结果。...,访问mysql中执行SQL的次数只有第一次读取的时候执行。...,所以mysql执行日志有两次,如下: 限制查询集 可以对查询集进行取下标或切片操作,等同于sql中的limit和offset子句。
ORM 查询操作 修改 views.py 文件 from django.shortcuts import render, HttpResponse from app01 import models from...Book,Author,Publisher def data_oper(req): # 查询所有出版社城市为 广州 的书名 ret = models.Book.objects.filter...(publisher__city='广州').values('title') print(ret) # 查询对应操作的sql语句 print(ret.query) return...ORM 删除操作 修改 views.py 文件 from django.shortcuts import render, HttpResponse from app01 import models from...id 为 1 的记录 models.Book.objects.filter(id=1).delete() return HttpResponse("Hello world") ORM
在ORM层面,这些查询条件都是使用field+__+condition的方式来使用的。以下将那些常用的查询条件来一一解释。 查询条件 exact 使用精确的=进行查找。...QuerySet.query QuerySet.query:query可以用来查看这个ORM查询语句最终被翻译成的SQL语句。...但是query只能被用在QuerySet对象上,不能用在普通的ORM模型上。...因此如果你的查询语句是通过get来获取数据的,那么就不能使用query,因为get返回的是满足条件的ORM模型,而不是QuerySet。...根据关联的表进行查询 假如现在有两个ORM模型,一个是Article,一个是Category。
数据库的查询需要使用管理器对象进行 通过mymodel.objects管理器方法调用查询对象 方法 说明 all() 查询全部记录,返回QuerySet查询对象 get() 查询符合条件的单一记录 filter...,需要用字典的取值方法 values_list方法 ---- 用法:Asset.objects.values_list() 作用:以元组的方式查询结果 返回值:QuerySet容器对象...,内部存放的是元组 会将查询出来的数据封装到元组中,在封装到查询集合QuerySet中 >>> a = Asset.objects.values_list("create_date") >>> a...取值方法: print(元组名[索引]) order_by方法 ---- 用法:Asset.objects.order_by('-列','列') 作用:与all()方法不同,他会用SQL语句的ORDER_BY...(属性1=值1,属性2=值2),当多个属性在一起为与关系 作用:返回包含此条件的全部数据集 返回值:QuerySet容器对象,内部存放模块实例 # 查询数据库中 create_user为admin的 from
Django 的 ORM 是创建 SQL 去查询和操作数据库的一个 Python 式的方式。...聚合查询 aggregate() 是 QuerySet 的一个终止子句,它返回一个包含一些键值对的字典。 键的名称是聚合值的标识符,值是计算出来的聚合值。
外键是在用户表里面 需求(1) 根据查询出来的用户,获取他的用户类型,这个就是多表查询,实现代码是 先查询出用户,直接根据外键字段获取他的用户类型 需求(2) 根据一个用户类型,查询他下面的所有的用户...其实有一个隐含的字段,写法是 总结 value()函数,获取列表 value()函数,获取元组 总结 以上方法 字典和元组是不可以跨表查询的 以下的写法是可以跨表的
Django 的 ORM 是创建 SQL 去查询和操作数据库的一个 Python 式的方式。 F查询 Q查询 F 查询 在前几个小章节里,构造的过滤器都只是将字段值与某个常量做比较。...Django 提供了 F() 来做这样的比较。F() 的实例可以在查询中引用字段,来比较同一个 model 实例中两个不同字段的值。...示例: 查询浏览数大于评论数的文章 Django 支持 F() 对象之间以及 F() 对象和常数之间的加减乘除和取模的操作。...示例: 查询作者是“小团子”或“yuntuan”的文章 可以组合 & 和 | 操作符以及使用括号进行分组来编写任意复杂的 Q 对象。...示例: 查询发布年份是2018或2019,文章标题中带“博客”的所有书。 ?
###多表查询 一般的多表查询都是直接建立一个多对多关系 class Books(models.Model): users = models.ManyToManyField(User, related_name...models.DateTimeField(auto_now_add=True) updated_at = models.DateTimeField(auto_now=True) 这个时候列举一些查询场景...1、根据books中的属性来查询用 Books.objects.filter(name="aaa") 2、根据assets中的title来查询books,这个时候就需要用到related_name属性来查询...="aaa") 也可以查询assets然后反向查询 _books=list() aa=Assets.objects.filter(title="aaa").all() for a in aa: _...,这个时候就需要用到django提供的Q类来封装查询语句 Books.objects.filter(Q(name__icontains=search) | Q(t_assets__title__icontains
Django 的 ORM 是创建 SQL 去查询和操作数据库的一个 Python 式的方式。...回顾上节的知识点 注:Tb 为 模型 model 的 Class 名,比如 Post.objects.all() 1.返回 QuerySet 对象的方法 >>> Tb.objects.all() >>...Tb.objects.exclude() >>> Tb.objects.order_by() >>> Tb.objects.reverse() >>> Tb.objects.distinct() 2.特殊的QuerySet...Tb.objects.first() >>> Tb.objects.last() 续 4.返回布尔值的方法 >>> Tb.objects.exists() 5.返回数字的方法 >>> Tb.objects.count() 单表查询
查询 Django ORM可以通过一些方法来实现。其中的很多方法返回的是Django自定义的QuerySet类的迭代器。Python看到迭代器时会懒惰求值,所以这些方法返回时并不会真正进行数据库操作。...因此,在写程序时,要注意QuerySet求值的时间点,避免重复的数据库操作。 SQL的WHERE条件可以通过参数的形式来传给方法。...我觉得这种情况下,可以直接上原始的SQL查询语句了,没必要再自己折腾自己。 F表达式和Q表达式 F表达式指代了一列,对于update操作时引用列的值有用。...这些都是Django ORM用来弥补缺陷的。就拿Q表达式来说。查询方法中跟多个参数的话,相当于多个WHERE条件。这些条件会默认为AND关系。...但如果需要构建复杂的SQL语句,与其在Django ORM里绕来绕去,还不如直接用原始的SQL语句。这个是我最强烈的一个感受。当然,Django ORM还是可用的工具。
对象和关系之间并不是完美映射 一般来说 ORM 足以满足我们的需求,如果对性能要求特别高或者查询十分复杂,可以考虑使用原生 SQL 和 ORM 共用的方式 Django ORM 在 Django 框架中集成了...使用 Python 的切片语法可以限制 QuerySet 的实例数量,ORM 会将翻译成 SQL 的 LIMIT 和 OFFSET 子句,下面是几个例子: 放回 QuerySet 的前 5 个元素 返回...、ManyToManyField,例如下图中的 orm_author 就与多个 orm_blog 实例关联 因此 Django ORM 中的关联查询也分两中 select_related(单关联实例)...`author_id` IN (1) 如果查询出关联对象的 QuerySet 之后,再对该 QuerySet 执行查询条件,会使该 QuerySet 失效(也就是需要再次访问数据库)。...原始 SQL 查询 使用 Manager 的 raw 方法可以用于原始的 SQL 查询,并返回 Model 的实例: blogs = Blog.objects.raw('select * from orm_blog
查看Django ORM生成的MySQL数据库的SQL语句 Django ORM生成的MySQL数据库的SQL语句其实可以通过打印QuerySet对象的query属性来查看,但是这样只能查看到对应的SQL...通过QuerySet对象的query属性来查看SQL语句 >>> from book.models import BookInfo >>> objs = BookInfo.objects.all() >...`is_delete` FROM `bookinf 通过MySQL日志来查看SQL语句 首先,这需要开启Mysql的日志记录功能。...tail -f /var/log/mysql/query.log 现在在Django的shell中做数据库操作,MySQL的日志这里就会有显示。...例如: 这样,我们在Django中如果需要优化ORM的查询,可以通过查看MySQL日志来进行分析定位,查看问题所在。
那么是否可以查询数据呢?实际上由于“一个模型类的实例代表数据库表中的一行记录”,因此模型类的实例是不能起到查询数据的功能。 Manager 因此,我们要从数据库检索到数据,ORM就必须提供相应的方法。...除非以下两种情况: 添加额外的 Manager 方法; 修改 Manager 返回的原始 QuerySet。 有关如何自定义Manager,在Django管理器中有详细说明。...在 SQL 的层面上, QuerySet 对应 SELECT 语句,而filters对应类似 WHERE 或 LIMIT 的限制子句。...什么时候QuerySet被执行? 在Django的文档中,明确的告诉了开发者,什么时候QuerySet被执行。因为这影响到SQL执行效率。...QuerySet 类具有两个可用于自省的公开属性: 可以返回QuerySet对象的QuerySet方法 前文所述的看起来做了3次SQL查询,实际上只有一次。
一、反向连表查询 ① 通过object的形式反向连表 obj.小写表名_set.all() publish=models.Publish.objects.filter(name__contains='长沙...authorobj.book_set.add(*objects) authorobj.save() ③ 通过values双下滑线的形式 objs.values("小写表名__字段") 注意对象集合调用values(),正向查询是外键字段...models.Book.objects.filter(title__icontains='云团').values('author__name') print(authors) filter()也支持__小写表名语法进行连表查询
对象关系映射 (ORM) 使得与SQL数据库交互更为简单,不过也被认为效率不高,比原始的SQL要慢。 要有效的使用ORM,意味着需要多少要明白它是如何查询数据库的。...本文我将重点介绍如何有效使用 Django ORM系统访问中到大型的数据集。...Django的queryset是惰性的 Django的queryset对应于数据库的若干记录(row),通过可选的查询来过滤。...要真正从数据库获得数据,你需要遍历queryset: for person in person_set: print(person.last_name) Django的queryset是具有cache...的 当你遍历queryset时,所有匹配的记录会从数据库获取,然后转换成Django的model。
,如果希望显示ORM框架执行的SQL语句,就可以使用该日志记录器。...,这里我们关注的是ORM框架生成的SQL查询到底是什么样子的, 相信这里的结果会让你感到有一些意外。...“N+1查询”),原本获取老师的数据只需要一条SQL,但是由于老师关联了学科,当我们查询到N条老师的数据时,Django的ORM框架又向数据库发出了N条SQL去查询老师所属学科的信息。...在一条SQL中可以基于连接查询完成老师和学科的查询。...可以用QuerySet的only()方法来指定需要查询的属性,也可以用QuerySet的defer()方法来指定暂时不需要查询的属性,这样生成的SQL会通过投影操作来指定需要查询的列,从而改善查询性能,
目录 Django ORM单表操作 Django 测试环境搭建 ORM 创建表 ORM 添加数据 ORM 查询数据 all 查询 filter 查询 exclude 取反查询 get 查询 order_by...ORM 修改数据 ORM 逆转到 SQL Django ORM单表操作 Django 测试环境搭建 注意pycharm链接数据库都需要提前下载对应的驱动,自带的sqlite3对日期格式数据不敏感,...", "day06.settings") import django django.setup() 直接使用pycharm提供的python console ORM 创建表 # Mysql...查询数据 all 查询 all()方法查询所有数据,返回一个QuerySet对象,类似list,可以通过索引来获取列表中的对象,这里不支持负索引 from django.shortcuts import...逆转到 SQL 方式一: 如果想打印orm转换过程中的sql,需要在settings中进行如下配置: '''settings.py''' LOGGING = { 'version': 1,