首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Django-官网查询部分翻译(1.11版本文档)-QuerySet-字段查找-06

django(ORM)中,数据库与 python 对象的映射关系十分形象,一个表模型类(class)即代表一张表,实例化出一个对象即代表一条数据记录 创建一个对象(一条数据记录) 在 django...,下面的语句是更新一个 Entry 模型类实例化出来的 entry 对象的 blog 属性(请确保下面用到的 Entry 和 Blog 的实例化对象已经存在在数据库中,这样我们的语句才能将它们查出来)...记住这个 使用 .get() 和 .filter()[0] 有点不一样,如果没有满足条件的查询结果, .get() 会报一个 DoesNotExist 的错,这个报错是执行的表模型类的一个属性,所以,在上面的代码中...同样,如果有多个对象同时满足这个条件,那么 django 将会报错:MultipleObjectsReturned,这个报错也是执行的模型类的一个属性。...,里面包含的对象都是满足你给出的查询参数(条件)的,多个查询(关键字)参数以逗号间隔,对应到 SQL 语句中是 AND 连接,如果你想执行更多复杂的操作(比如 OR 或)可以使用 Q 对象 Q对象 的使用

2.9K20

django 1.8 官方文档翻译: 2-2-1 执行查询

字段筛选条件 字段筛选条件就是 SQL 语句中的 WHERE 从句。就是 Django 中的 QuerySet 的 filter(), exclude() 和 get() 方法中的关键字参数。...如果我们要对两个字段的值做比较,那该怎么做呢? Django 提供 F() 来做这样的比较。F() 的实例可以在查询中引用字段,来比较同一个 model 实例中两个不同字段的值。...Django 1.0 中新增的: 请查看版本文档 有时你想对 QuerySet 中的所有对象,一次更新某个字段的值。...在调用 update 时可以使用 F() 对象 来把某个字段的值更新为另一个字段的值。...) 但是,与 F() 对象在查询时所不同的是,在filter 和 exclude子句中,你不能在 F() 对象中引入关联关系(NO-Join),你只能引用当前 model 中要更新的字段。

4.4K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【Django】 开发:数据库操作和后台管理

    F F('列名') 说明: 一个 F () 对象代表了一个 model 的字段的值 F 对象通常是对数据库中的字段值在不加载到内存中的情况下直接在数据库服务器端进行操作 示例 1 更新 Book...需要先导入再使用 from django.db.models import Q 作用 在条件中用来实现除 and (&) 以外的 or (|) 或 not (~) 操作 运算符: & 与操作 | 或操作...='机械工业出版社')) 原生的数据库操作方法 使用MyModel.objects.raw()进行 数据库查询操作查询 在django中,可以使用模型管理器的raw方法来执行select语句进行数据查询...中的游标cursor对数据库进行 增删改查 操作 在 Django 中跨过模型类直接操作数据库 使用步骤: 导入 cursor 所在的包 Django 中的游标 cursor 定义在 django.db.connection...(设置完成后需要立马更新同步数据库) 2. verbose_name = '单数名' - 给模型对象的一个易于理解的名称(单数),用于显示在/admin管理界面中

    4.1K40

    Q查询和F查询

    当 Django 遇到 F() 的实例时,它会覆盖标准的 Python 运算符来创建一个封装的 SQL 表达式;在本例中,它指示数据库递增由 reporter.stories_filed 表示的数据库字段...避免竞争 F() 的另一个有用的好处是,让数据库——而不是 Python——更新一个字段的值,避免了 竞争条件。...如果数据库负责更新字段,那么这个过程就比较稳健:它只会在执行 save() 或 update() 时,根据数据库中字段的值来更新字段,而不是根据检索实例时的值来更新。...注意:F() 赋值在 Model.save() 之后持续存在 F() 分配给模型字段的对象在保存模型实例后会持续存在,并将应用于每个 save()。...根据字段的值来进行查询 F() 在 QuerySet 过滤器中也非常有用,它们可以根据对象的字段值而不是 Python 值的标准来过滤一组对象。F()能将模型字段值与同一模型中的另一字段做比较。

    1.4K10

    Django框架学习(三)

    Django中: 1、设置模板目录 在工程中创建模板目录templates。...父模板 如果发现在多个模板中某些内容相同,那就应该把这段内容定义到父模板中。 标签block:用于在父模板中预留区域,留给子模板填充差异性的内容,名字不能相同。...b)Django中的模板变量不能直接进行算术运算 2、模板控制语句:条件判断和for循环 a)条件判断:Django模板中在进行条件判断时候,比较操作符两边必须有空格 b)for循环:Django模板中的...__tablename__ = "" 2)Django中定义模型类 class 模型类名(models.Model): # 字段名 = models.字段类型(选项参数) #...字段类型 类型 说明 AutoField 自动增长的IntegerField,通常不用指定,不指定时Django会自动创建属性名为id的自动增长属性 BooleanField 布尔字段,值为True或False

    1.8K40

    django入门:数据模型

    的社群,有想学习django的同学可以在公众号后台回复“django”,获取入群方式。...正文 上一部分我们介绍了《django环境和项目的搭建》,以及数据库的配置,那这一部分我们介绍和数据库相关方面的知识 -- 模型 创建 django 模型 我们需要在 "blog" 应用下的 models.py...文件中添加 django 数据库模型,模型类需要继承 models.Model 类,例如 from django.db import models class Category(models.Model...列 auto_now=(True/False) 自动创建---无论添加或修改,都是当前操作的时间,在 MySql 下存在过滤月份时候数据为空,解决方案参考 MySql 文档 Section...category = models.ForeignKey(Category) 在表 Category 中需要统计某个 category 下 post 数量, # 但是表 Category 中没有 post_count

    83710

    一杯茶的时间,上手 Django 框架开发

    >Hello World Tom 条件语句 条件语句的定义如下: {% if is_true %} It is true!...注意:整个条件语句必须以 {% endif %} 结束,并且 {% else %} 是可选的。 循环语句 循环语句用来在模板上展示任意长的列表内容。...理解数据库迁移 数据库迁移是指将用 Django 定义的模型转换成 SQL 代码(即迁移文件),并在数据库中进行建表操作(或更新表)。看下面这张图就知道了: ?...4.在开发中发现第 1 步中定义的模型不完善,更新数据模型5.跳转到第 2 步,反复循环 实现第一个数据模型 终于到了动手的环节。...Django 还有很多很多的高级玩法,例如数据模型中的高级查询、字段索引、更换数据库等等,模板中的继承机制、内部标签等等,还有视图中如何处理各类请求(POST、PUT等),我们会在后续更多教程中逐一为大家讲解

    1.5K21

    Django学习笔记:QuerySet API

    其实模型名字.objects是一个django.db.models.manager.Manager对象,而Manager这个类是一个“空壳”的类,他本身是没有任何的属性和方法的。...默认情况下会把表中所有的字段全部都提取出来,可以使用values来进行指定,并且使用了values方法后,提取出的QuerySet中的数据类型不是模型,而是在values方法中指定的字段和值形成的字典:...update:执行更新操作,在SQL底层走的也是update命令。比如要将所有category为空的article的article字段都更新为默认的分类。...所以更新完成后保存到数据库中不会执行save方法,因此不会更新auto_now设置的字段。 delete:删除所有满足条件的数据。删除数据的时候,要注意on_delete指定的处理方式。...说明上面的QuerySet并没有真正的执行。 在以下情况下QuerySet会被转换为SQL语句执行: 迭代:在遍历QuerySet对象的时候,会首先先执行这个SQL语句,然后再把这个结果返回进行迭代。

    63320

    django 1.8 官方文档翻译:2-5-9 条件表达式

    条件表达式 New in Django 1.8. 条件表达式允许你在过滤器、注解、聚合和更新操作中使用 if ... elif ... else的逻辑。...条件表达式为表中的每一行计算一系列的条件,并且返回匹配到的结果表达式。条件表达式也可以像其它 表达式一样混合和嵌套。...=0), then=1) Case class Case(*cases, **extra)[source] Case()表达式就像是Python中的if ... elif ... else语句。...如果没有条件为TRUE,表达式会返回提供的default关键字参数。如果没有提供default参数,会使用Value(None)。...这就像Python中的if … elif … else语句一样。 高级查询 条件表达式可以用于注解、聚合、查找和更新。它们也可以和其它表达式混合和嵌套。这可以让你构造更强大的条件查询。

    37130

    05.Django基础五之django模型层(一)单表操作

    创建名为book的app,在book下的models.py中创建模型: from django.db import models # Create your models here....(4)unique 如果该值设置为 True, 这个数据字段的值在整张表中必须是唯一的 (5)choices 由二元组组成的一个可迭代对象(例如,列表或元组),用来给字段提供选择项。...,我们接着往下看 具有auto_now属性字段的更新 我们通常会给表添加三个默认字段 - 自增ID,这个django已经默认加了,就像上边的建表语句,虽然只写了username和is_active两个字段...,django有一张django-migrations表,表中记录了已经执行的脚本,那么表中没有的就是还没执行的脚本,则 执行migrate的时候就只执行表中没有记录的那些脚本。...有时在执行 migrate 的时候如果发现没有生成相应的表,可以看看在 django-migrations表中看看 脚本是否已经执行了, 可以删除 django-migrations 表中的记录

    3K10

    后端框架学习-Django

    /templates 在settings.py中TEMPLATE配置项 BACKEND:指定模板引擎 DIRS:模板的搜索目录(可以是一个或多个) APP_DIRS:是否在应用中的templates文件夹中搜索末班文件...名称+类名称小写 模型类-字段类型: BooleanField 数据库类型:tinyint(1) 编程语言中将使用True或False来表示值 在数据库中则使用0或1来表示具体的值 Char...verbose_name:设置此字段在admin界面上的显示名称,可以中文化admin界面 好习惯:字段选项【添加或更改】均要执行 模型类-Meta内部类 使用Meta类来给**模型(其实就是表的属性)...(key)-获取缓存 key:缓存的key 返回值,key的对应值,没有则返回None 3.cache.add(key,value)-存储缓存,只在key不存在的时候生效 返回值:True或...中间件以类的形式体现 每个中间件负责一些特定的功能 中间件方法 继承django.utils.deprecation.MiddlewareMixin类 中间件类须实现下列五个方法中的一个或多个: process_request

    9.6K40

    Django项目知识点(四)

    QuerySet实例 就是从数据库根据自己要求拿数据的 连数据都那不出来,写啥视图 所以在编写queryset必须用django shell 调试 在model中,Django通过给Model增加一个objects...当我们需要对查询集(queryset)的某些字段进行计算或进行先分组再计算或排序, 我们就需要使用aggregate和annotate方法了。...aggregate(Max('price')) {'price__max': Decimal('81.20')} annotate 先介绍F,annotate 必用F F介绍 -个F()对象表示一个模型字段或注释的列的值...这样就可以引用模型字段值并使用它们执行数据库操作,而无需实际将它们从数据库中拉出到Python内存中 说白了就是我从数据库拿东西,但是有些需要的字段没有,要通过绑定的外键的app的model拿。...news中的title字段,拿出来它叫news__title,我要给它换个名字叫news_title,这就是注释。

    1.6K30

    Django ORM模型:想说爱你不容易

    Django的数据模型的建立过程很简单,就是继承django.db.models中的Model类,然后给它增加属性。每一个属性可以对应关系数据库中的一个字段。...这里的max_length=10对应了限制条件: VARCHAR(10) (在MySQL V4中,代表了10个字节;在MySQL V5中,代表了10个字符。)...有一些限制条件是Django提供的,并没有数据库层面的对应物,比如blank。 (当blank参数为真时,对应字段可以为留为空白。) 在基本的模型设计上,Django ORM没有留什么坑。...需要注意的是,在Django ORM中,只能通过ForeignKey来定义多对一关系,不能显示地定义一对多关系。但你可以使用模型对象的*_set语法来反向调用多对一关系。...但如果需要构建复杂的SQL语句,与其在Django ORM里绕来绕去,还不如直接用原始的SQL语句。这个是我最强烈的一个感受。当然,Django ORM还是可用的工具。

    64320

    Django ORM模型:想说爱你不容易

    Django的数据模型的建立过程很简单,就是继承django.db.models中的Model类,然后给它增加属性。每一个属性可以对应关系数据库中的一个字段。...这里的max_length=10对应了限制条件: VARCHAR(10) (在MySQL V4中,代表了10个字节;在MySQL V5中,代表了10个字符。)...有一些限制条件是Django提供的,并没有数据库层面的对应物,比如blank。 (当blank参数为真时,对应字段可以为留为空白。) 在基本的模型设计上,Django ORM没有留什么坑。...需要注意的是,在Django ORM中,只能通过ForeignKey来定义多对一关系,不能显示地定义一对多关系。但你可以使用模型对象的*_set语法来反向调用多对一关系。...但如果需要构建复杂的SQL语句,与其在Django ORM里绕来绕去,还不如直接用原始的SQL语句。这个是我最强烈的一个感受。当然,Django ORM还是可用的工具。

    1.3K80

    Django ORM模型:想说爱你不容易

    Django的数据模型的建立过程很简单,就是继承django.db.models中的Model类,然后给它增加属性。每一个属性可以对应关系数据库中的一个字段。...这里的max_length=10对应了限制条件: VARCHAR(10) (在MySQL V4中,代表了10个字节;在MySQL V5中,代表了10个字符。)...有一些限制条件是Django提供的,并没有数据库层面的对应物,比如blank。 (当blank参数为真时,对应字段可以为留为空白。) 在基本的模型设计上,Django ORM没有留什么坑。...需要注意的是,在Django ORM中,只能通过ForeignKey来定义多对一关系,不能显示地定义一对多关系。但你可以使用模型对象的*_set语法来反向调用多对一关系。...但如果需要构建复杂的SQL语句,与其在Django ORM里绕来绕去,还不如直接用原始的SQL语句。这个是我最强烈的一个感受。当然,Django ORM还是可用的工具。

    78920

    【Python全栈100天学习笔记】Day41 Django深入理解框架

    在MySQL中创建数据库的SQL语句如下所示: create database oa default charset utf8; Django框架本身有自带的数据模型,我们稍后会用到这些模型,为此我们先做一次迁移操作...至此我们还没有看到之前创建的模型类,需要在应用的admin.py文件中模型进行注册。 注册模型类。...语句并获取对应的结果,这一点在实际开发中需要引起注意!...说明3:可以在QuerySet上使用update()方法一次更新多个对象。...模型定义参考 字段 对字段名称的限制 字段名不能是Python的保留字,否则会导致语法错误 字段名不能有多个连续下划线,否则影响ORM查询操作 Django模型字段类 字段类 说明 AutoField

    2.3K30

    Django——model基础

    (4)unique 如果该值设置为 True, 这个数据字段的值在整张表中必须是唯一的 (5)choices 由二元组组成的一个可迭代对象(例如,列表或元组),用来给字段提供选择项。...在更新多对多的第三张表时,可以直接用以下方法 book_obj.authors.set(*[装有对象id的列表]) 此操作包含了两步clear+add 有时候字段获取的较多,但是需要更新的表里没有那么多字段...如果我们要对两个字段的值做比较,那该怎么做呢? Django 提供 F() 来做这样的比较。F() 的实例可以在查询中引用字段,来比较同一个 model 实例中两个不同字段的值。 ?...里面的条件可能有多个条件符合,比如name='alvin',可能有两个name='alvin'的行数据)。...在“插入和更新数据”小节中,我们有提到模型的save()方法,这个方法会更新一行里的所有列。 而某些情况下,我们只需要更新行里的某几列。

    1.1K100

    Django学习-第十讲(上):QuerySet API 学习

    其实模型名字.objects是一个django.db.models.manager.Manager对象,而Manager这个类是一个“空壳”的类,他本身是没有任何的属性和方法的。...默认情况下会把表中所有的字段全部都提取出来,可以使用values来进行指定,并且使用了values方法后,提取出的QuerySet中的数据类型不是模型,而是在values方法中指定的字段和值形成的字典...>等 7.all:获取这个ORM模型的QuerySet对象。 select_related:在提取某个模型的数据的同时,也提前将相关联的数据提取出来。...比如可以提前获取文章的作者,但是不能通过作者获取这个作者的文章,或者是通过某篇文章获取这个文章所有的标签 9.prefetch_related:这个方法和select_related非常的类似,就是在访问多个表中的数据的时候...所以更新完成后保存到数据库中不会执行save方法,因此不会更新auto_now设置的字段 14.切片操作:有时候我们查找数据,有可能只需要其中的一部分 books = Book.objects.all

    59620

    Django(19)QuerySet API

    其实模型名字.objects是一个django.db.models.manager.Manager对象,而Manager这个类是一个“空壳”的类,他本身是没有任何的属性和方法的。...默认情况下会把表中所有的字段全部都提取出来,可以使用values来进行指定,并且使用了values方法后,提取出的QuerySet中的数据类型不是模型,而是在values方法中指定的字段和值形成的字典:...如果在values中没有传递任何参数,那么将会返回一个字典,字典中包含这个模型中所有的属性。...update update:执行更新操作,在SQL底层走的也是update命令。比如要将所有category为空的article的article字段都更新为默认的分类。...Django将QuerySet转换为SQL语句去执行的五种情况 迭代:在遍历QuerySet对象的时候,会首先先执行这个SQL语句,然后再把这个结果返回进行迭代。

    74310
    领券