获取对象 通过模型中的Manager构造一个QuertSet,来从你的数据库中获取对象。 QuerySet表示你数据库中取出来的一个对象的集合。...它可以含有零个、一个或者多个过滤器,过滤器根据所给的参数限制查询结果的范围。在sql的角度,QuerySet和SELECT命令等价,过滤器是像WHERE和LIMIT一样的限制子句。...限制查询集范围 可以用 python 的数组切片语法来限制你的 QuerySet 以得到一部分结果。它等价于SQL中的 LIMIT 和 OFFSET 。...字段筛选条件 字段筛选条件就是 SQL 语句中的 WHERE 从句。就是 Django 中的 QuerySet 的 filter(), exclude() 和 get() 方法中的关键字参数。...QuerySet 第一次运行时,会执行数据库查询,接下来 Django 就在 QuerySet 的缓存中保存查询的结果,并根据请求返回这些结果(比如,后面再次调用这个 QuerySet 的时候)。
Retrieving objects 查出对象(QuerySet) 从数据库中查询对象,通过 表模型类的 Manager 管理器 来构造一个 QuerySet 。...一个 QuerySet 代表着你数据库中的一系列对象的集合,它可以是 0 个、 1 个 或者多个 filters,filters 可以基于你给出的参数 缩小查询结果的范围,对于 SQL ,一个 QuerySet...(字段查询条件,双下划线查询) 此部分参考文档: django官网 字段查找(field-lookups) 字段查找(field-lookups)对应的是 SQL 语句中的 WHERE 条件,一般放在...QuerySet 对象的 filter() 、exclude()、get() 方法中作为条件 常见形式 注意点 不同数据库对这些方法支持不同,django orm 对应不同数据库也能翻译成不同的 SQL...|The) +'; # -- MySQL,对于这个字段查询,django orm 对应不同的 数据库 会解析成不同的 SQL 语句 __iregex # 忽略大小写的正则匹配 # 案例 Entry.objects.get
Django的数据模型的建立过程很简单,就是继承django.db.models中的Model类,然后给它增加属性。每一个属性可以对应关系数据库中的一个字段。...有一些限制条件是Django提供的,并没有数据库层面的对应物,比如blank。 (当blank参数为真时,对应字段可以为留为空白。) 在基本的模型设计上,Django ORM没有留什么坑。...需要注意的是,在Django ORM中,只能通过ForeignKey来定义多对一关系,不能显示地定义一对多关系。但你可以使用模型对象的*_set语法来反向调用多对一关系。...真希望有一种显式说明关系的办法,降低读代码时的认知负担。 查询 Django ORM可以通过一些方法来实现。其中的很多方法返回的是Django自定义的QuerySet类的迭代器。...因此,在写程序时,要注意QuerySet求值的时间点,避免重复的数据库操作。 SQL的WHERE条件可以通过参数的形式来传给方法。
Django的Manager和QuerySet 要从数据库检索对象,需要通过模型类的 Manager 构建一个 QuerySet。...那么是否可以查询数据呢?实际上由于“一个模型类的实例代表数据库表中的一行记录”,因此模型类的实例是不能起到查询数据的功能。 Manager 因此,我们要从数据库检索到数据,ORM就必须提供相应的方法。...可以根据给定参数缩小查询结果量。在 SQL 的层面上, QuerySet 对应 SELECT 语句,而filters对应类似 WHERE 或 LIMIT 的限制子句。...在Django的文档中,明确的告诉了开发者,什么时候QuerySet被执行。因为这影响到SQL执行效率。...字段查找 由于字段查询非常多,也非常常用,本文不进行说明。请直接参考Django字段查询 参考资料: 执行查询 QuerySet API参考 管理器
通过使用 ORM,我们只需要操作 Author 和 Blog 对象,而不用操作相关的数据库表。这里主要介绍一下 Django ORM 的相关使用。...从数据库中查询出来的结果一般是一个集合,这个集合称为 QuerySet。...QuerySet 有两种来源:通过 Manager 的方法获取、通过 QuerySet 自身的方法获得。...`name` = 'zjk' 限制 QuerySet 有时候我们并不需要获取查询集的全部数据,而只需要一个子集,一个常见的场景就是进行分页查询。...`id` = 1 迭代:在首次迭代查询集时会执行数据库查询 切片(限制查询集):对查询集执行切片操作时,指定 step 参数 序列化/缓存 repr:对查询集调用 repr 函数 len:对查询集调用
从数据库中查询出来的结果一般是一个集合,这个集合叫做 QuerySet。...若要按照另外一个模型中的字段排序,可以使用查询关联模型的语法。即通过字段的名称后面跟两个下划线(__),再加上新模型中的字段的名称,直到希望连接的模型。...()被调用,不会再去数据库查找,而是在一个预取的QuerySet缓存中查找。...当最初获取数据时不知道是否需要这些特定字段的情况下,如果正在使用查询集的结果,可以告诉Django不要从数据库中检索它们。...通过传递字段名称到defer()实现不加载: Entry.objects.defer("headline", "body") 具有延迟加载字段的查询集仍将返回模型实例。
一 QuerySet 可切片 使用Python 的切片语法来限制查询集记录的数目 。它等同于SQL 的LIMIT 和OFFSET 子句。...首次对查询集进行求值 —— 同时发生数据库查询 ——Django 将保存查询的结果到查询集(非简单查询的查询结果,简单查询往下看。)...也可以通过使用双下划线“__”连接字段名来实现指定的递归查询。 没有指定的字段不会缓存,没有指定的深度不会缓存,如果要访问的话Django会再次进行SQL查询。...也可以通过depth参数指定递归的深度,Django会自动缓存指定深度内所有的字段。如果要访问指定深度外的字段,Django会再次进行SQL查询。...也接受无参数的调用,Django会尽可能深的递归查询所有的字段。但注意有Django递归的限制和性能的浪费。 Django >= 1.7,链式调用的select_related相当于使用可变长参数。
切片未执行的QuerySet通常会返回另一个未执行的Query Set。但是,如果使用切片语法的step参数,Django将执行数据库查询并返回一个列表。...有关拾取QuerySet的详细信息,请参阅下一节。在本节中,从数据库中读取结果非常重要。 repr()调用repr()时,将执行QuerySet。...这意味着当取消缓存QuerySet时,它包含缓存时的结果,而不是数据库中当前的结果。 如果只想提取将来从数据库中重新创建QuerySet所需的信息,请提取QuerySet的查询属性。...表达式可以是简单值、对模型(或任何相关模型)字段的引用,或计算与QuerySet中的对象相关的对象的聚合表达式(平均值、总和等)。...annotation()的每个参数都是一个注释,将添加到返回的QuerySet中的每个对象。 Django提供的聚合函数在以下聚合函数中进行了描述。
另外,查询到的QuerySet又是缓存的,当再次使用同一个QuerySet时,并不会再查询数据库,而是直接从缓存获取(不过,有一些特殊情况)。...QuerySet的方法 数据库的常用操作就四种:增、删、改、查,QuerySet的方法涉及删、改、查。后面还会讲model对象的方法,model方法主要是增、删、改、还有调用model实例的字段。...只返回主表(即Author表)的所有字段值,即使在查询时关联了其它表,关联表的字段也不会返回,只有当我们通过Author instance用关联表时,Django才会再次查询数据库获取值。...代码2中,当遍历开始前,先拿到Entry的QuerySet,并且也拿到这个QuerySet的每个object中的blog对象,这样遍历过程中,就不用再查询数据库了,这样就减少了数据库读次数。...select_related是用select ……join来返回关联的表字段,而prefetch_related是用多条SQL语句的形式查询,一般,后一条语句用IN来调用上一句话返回的结果。
QuerySet 可切片 使用Python 的切片语法来限制查询集记录的数目 。它等同于SQL 的LIMIT 和OFFSET 子句。...在一个新创建的查询集中,缓存为空。首次对查询集进行求值 —— 同时发生数据库查询 ——Django 将保存查询的结果到查询集的缓存中并返回明确请求的结果(例如,如果正在迭代查询集,则返回下一个结果)。...也可以通过使用双下划线“__”连接字段名来实现指定的递归查询。 没有指定的字段不会缓存,没有指定的深度不会缓存,如果要访问的话Django会再次进行SQL查询。...也可以通过depth参数指定递归的深度,Django会自动缓存指定深度内所有的字段。如果要访问指定深度外的字段,Django会再次进行SQL查询。...也接受无参数的调用,Django会尽可能深的递归查询所有的字段。但注意有Django递归的限制和性能的浪费。 Django >= 1.7,链式调用的select_related相当于使用可变长参数。
一 ORM简介 MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库,这极大的减轻了开发人员的工作量...CharField 要求必须有一个参数 maxlength, 用于从数据库层和Django校验层限制该字段所允许的最大字符数. IntegerField #用于保存一个整数....类型的数据来调用,返回数据库中匹配查询(QuerySet)的对象数量。...2. select_related使用SQL的JOIN语句进行优化,通过减少SQL查询的次数来进行优化、提高性能。...查询价格在100到200之间的所有书籍名称及其价格 5 查询所有人民出版社出版的书籍的价格(从高到低排序,去重) 关于django连接mysql的时指定严格模式的配置 DATABASES = {
前言 django查询数据库的方法很多,不同的方法返回的结果也不太一样,本篇详细讲解关于查询的13个方法 返回对象是对象列表的: all(), filter(), exclude(), order_by...查询整张表sql : select * from hello_user django里面查询数据库不需要写sql语句 ret=表的类名称.objects.all() 返回的是整个表的内容, 这里返回的是可迭代对象...”123456” filter()查询的结果是可迭代对象,如果结果只有一个,可以通过下标取值。...).values_list(“user_name”, “mail”) distinct() 从返回结果中剔除重复纪录 由queryset对象调用,返回值是queryset 和sql里面的distinct...调用者:objects管理器 返回查询到model对象 (注意:查询结果有且只有一个才执行) 如果查询结果有多个,会报错MultipleObjectsReturned, 如果查询结果有0个,会报错DoesNotExist
django中配置mysql数据库 查询queryset时如果需要选取查询集中的某个子集的字段时, 应该用切片,或者first 选择某个子集对象,这样才能够使用到 子集的字段,直接queryset后选择字段会直接报错...一是在INSTALLED_APPS里面加入app名称; 二是配置数据库相关信息 View Code 定义数据库表结构 models.py 使用orm框架,不需要编写原生的sql语句 from django.db...blank 为True时,admin中可以为空。但是不限制数据库,要想限制数据库里,需要设置null。 choices 选择框。...从数据库中查询出来的结果一般是一个QuerySet集合。...[, , ]> 从外部的脚本调用Django的models表 import os, sys PROJECT_DIR = os.path.dirname
在MySQL中创建数据库的SQL语句如下所示: create database oa default charset utf8; Django框架本身有自带的数据模型,我们稍后会用到这些模型,为此我们先做一次迁移操作...字段属性primary_key用于设置主键,max_length用来设置字段的最大长度,db_column用来设置数据库中与字段对应的列,verbose_name则设置了Django后台管理系统中该字段显示的名称...说明2:查询多个对象的时候返回的是QuerySet对象,QuerySet使用了惰性查询,即在创建QuerySet对象的过程中不涉及任何数据库活动,等真正用到对象时(求值QuerySet)才向数据库发送SQL...在数据库中不要出现无效数据。 不要对QuerySet调用len()函数。 将QuerySet的exists()方法的返回值用于if条件。...模型定义参考 字段 对字段名称的限制 字段名不能是Python的保留字,否则会导致语法错误 字段名不能有多个连续下划线,否则影响ORM查询操作 Django模型字段类 字段类 说明 AutoField
>>> news.channel # 这时的channel是缓存的版本,不会造成数据库访问 方法的调用每次都会触发数据库查询 >>> news = News.objects.get(id=1) >...').all() n = news_list[0] print n.title # 会产生额外的查询语句 QuerySet.only() 只加载某字段,之后读取任何属性都会产生查询 使用 QuerySet.count...with的使用是关键 每次的QuerySet.count()调用都会产生查询 使用 QuerySet.update() 和 delete() 批量更新使用 QuerySet.update() 批量删除使用...QuerySet.delete() 批量操作不会调用类中定义的 save() 或 delete() 方法 直接使用外键的值 获取频道ID: news.channel_id 而不是: news.channel.id...批量插入 用 django.db.models.query.QuerySet.bulk_create() 批量创建对象,减少SQL查询的 数量。
QuerySet API 我们通常做查询操作的时候,都是通过模型名字.objects的方式进行操作。...QuerySet的方法 在使用QuerySet进行查找操作的时候,可以提供多种操作。比如过滤完后还要根据某个字段进行排序,那么这一系列的操作我们可以通过一个非常流畅的链式调用的方式进行。...(title__contains='hello') 3.annotate:给QuerySet中的每个对象都添加一个使用查询表达式(聚合函数、F表达式、Q表达式、Func表达式等)的新字段 将在每个对象中都添加一个...,那么就会查找出来,如果没有,则会创建并且存储到数据库中。...调用len函数:调用len函数用来获取QuerySet中总共有多少条数据也会执行SQL语句。
在数据库中而不是Python中做数据库的工作 比如: 在最基础的层面上,使用过滤器和反向过滤器对数据库进行过滤。 使用F 表达式在相同模型中基于其他字段进行过滤。 使用数据库中的注解和聚合。...如果上面那些都不够用,你可以自己生成SQL语句: 使用QuerySet.extra() extra()是一个移植性更差,但是功能更强的方法,它允许一些SQL语句显式添加到查询中。...另外,当建立起一个带有延迟字段的模型时,要意识到一些(小的、额外的)消耗会在Django内部产生。...使用QuerySet.update()和delete() 通过QuerySet.update()使用批量的SQL UPDATE语句,而不是获取大量对象,设置一些值再单独保存。...如果一个模型具有默认的顺序(Meta.ordering),并且你并不需要它,通过在查询集上无参调用order_by() 来移除它。 向你的数据库添加索引可能有助于提升排序性能。
QuerySet API: 我们通常做查询操作的时候,都是通过模型名字.objects的方式进行操作。...返回新的QuerySet的方法: 在使用QuerySet进行查找操作的时候,可以提供多种操作。比如过滤完后还要根据某个字段进行排序,那么这一系列的操作我们可以通过一个非常流畅的链式调用的方式进行。...annotate:给QuerySet中的每个对象都添加一个使用查询表达式(聚合函数、F表达式、Q表达式、Func表达式等)的新字段。...示例代码如下: obj,created= Category.objects.get_or_create(title='默认分类') 如果有标题等于默认分类的分类,那么就会查找出来,如果没有,则会创建并且存储到数据库中...调用len函数:调用len函数用来获取QuerySet中总共有多少条数据也会执行SQL语句。
领取专属 10元无门槛券
手把手带您无忧上云