django.db.models.query.QuerySet
1.可迭代
2.可切片

官方文档:https://docs.djangoproject.com/en/1.9/ref/models/querysets/

相关API
1.get(**kwargs)

  解释:返回与筛选条件相匹配的Model对象,返回结果有且只有一个。

  说明:如果符合条件的对象多于一个抛出MultipleObjectsReturned异常,如果没有找到抛出DoesNotExist异常

  语法:ModelName.objects.get(itemName=itemNameValue)

  例子:Author.objects.get(id=1)

2.all()

  解释:查询所有结果(懒加载),当查询的时候并不真实发送sql语句,用的时候才会真的去查询

  语法:ModelName.objects.all()

  例子:Author.objects.all(id=1)

3.filter(**kwargs)

  解释:包含了与所给的筛选条件相匹配的QuerySet

  语法:ModelName.objects.filter(itemName=itemNameValue)

  例子:Author.objects.filter(id=1)

4.exclude(**kwargs):

  解释:包含了与所给的筛选件不匹配的QuerySet,于filter正好相反

  语法:ModelName.objects.exclude(itemName=itemNameValue)

  例子:Author.objects.filter(id=1)

5.order_by(*fields)

  解释:对查询结果进行排序

  语法:ModelName.objects.all().order_by("itemName")

  例子:Author.objects.all().order_by("id")

6.reverse()

  解释:对查询结果反向排序

  语法:ModelName.objects.all().order_by("itemName").reverse()

  例子:Author.objects.all().order_by("id")

7.distinct()

  解释:对查询结果去重

  语法:ModelName.objects.all().distinct()

  例子:Author.objects.all().distinct()

8.values(*fields)

  解释:返回一个ValuesQuerySet(一个特殊的QuerySet)

  说明:运行后得到的不是一系列model的实例对象,而是一个可迭代的字段序列

  语法:ModelName.objects.filter(name=value).values("name","name")

  例子:Author.objects.filter(id=1).values("name","id")

9.values_list(*fields)

  解释:与values相似只是返回的是一个元组

  语法:ModelName.objects.filter(name=value).values_list("name","name")

  例子:Author.objects.filter(id=1).values_list("name","id")

10.count()

  解释:返回数据库中匹配查询的对象数量

  语法:ModelName.objects.filter(itemName=itemNameValue).count()

  例子:Author.objects.filter(name="xiaol").count()

11.first()/last()

  解释:第一条记录/最后一条记录

  语法:ModelName.objects.filter(itemName=itemNameValue).first()

  例子:Author.objects.filter(name="xiaol").last()

关联查询:

  方法:使用两个下划线(__)可以进行关联查询

  例子:查询AutherDetail的信息

  语法:AuthorDetail.objects.filter(id="2").values("sex","email", "author__name")

聚合查询:需要引入from django.db.models import *

  方法:使用aggreagte关键字

  用法:xxx.filter(查询条件).aggregate(别名=聚合函数('聚合字段'))

  语法:Author.objects.filter(name="xiaol").aggregate(myCount=Count('id'))

分组查询:需要引入from django.db.models import *

  方法:使用aggreagte关键字

  用法:xxx.filter(分组字段).annotate(分组后操作)

  语法:Author.objects.filter(name="xiaol").annotate(myCount=Count('id'))

11.Django数据库操作(查)的更多相关文章

  1. Django数据库操作(增删改查)

    Django数据库操作(增删改查) 创建数据库中的一个表 class Business(models.Model): #自动创建ID列 caption = models.CharField(max_l ...

  2. 从命令行运行django数据库操作

    从命令行运行django数据库操作,报错: django.core.exceptions.ImproperlyConfigured: Requested setting DEFAULT_INDEX_T ...

  3. Django 数据库操作

    Django 数据库操作 Django运算表达式与Q对象/F对象 1 模型查询 概述: 1 查询集:表示从数据库中获取的对象的集合 2 查询集可以有多个过滤器,通过 逻辑运算符连接 3 过滤器就是一个 ...

  4. django数据库操作和中间件

    数据库配置 django的数据库相关表配置在models.py文件中,数据库的连接相关信息配置在settings.py中 models.py相关相关参数配置 from django.db import ...

  5. Django数据库操作

    刚学到Django的数据库操作,把它记录下来,方便以后查看: 在Django中定义数据库表,并使用Django提供的方法来对数据库进行操作(增.删.改.查) 1.定义3个数据库表: class Gro ...

  6. django数据库操作-增删改查-多对多关系以及一对多(外键)关系

    一.一对多(外键) 例子:一个作者对应多本书,一本书只有一个作者 model代码: class Person(models.Model); name = models.CharField('作者姓名' ...

  7. 转: django数据库操作-增删改查-多对多关系以及一对多(外键)关系

    原文链接:http://blog.csdn.net/u010271717/article/details/22044415 一.一对多(外键) 例子:一个作者对应多本书,一本书只有一个作者 model ...

  8. django 数据库操作详解

    Django配置使用mysql数据库 修改 settings.py 中的 DATABASES  注意:django框架不会自动帮我们生成mysql数据库,所以我们需要自己去创建. DATABASES ...

  9. Python Django 数据库操作

    1. 建立app 在自己的工程项目目录下输入: python manage.py startapp myapp(你想建立的app名称) 建立一个叫myapp的app 这样,在你的工程项目目录下会出现一 ...

随机推荐

  1. Datatable和实体还有实体集List的差别与转化

    机房收费系统大家想必不是做完.就是已经在手上了,在一開始做的时候就明白规定.我们必须用实体.而不能使Datatable,由于说是Datatable直接面向了数据库,当时不是非常明白,于是也没有再深究, ...

  2. Java之Jackson框架

    在Jackson框架中,提供了三种方式用来处理JSON数据: 流式API 在该方式下,使用JsonParser读取JSON数据,使用JsonGenerator写JSON数据.这种方式性能最佳(最低开销 ...

  3. Spring 应用外部属性文件 配置 context 错误

    在Spring配置文件中出现通配符的匹配很全面, 但无法找到元素 'context:property-placeholder' 的声明这个错误,其实主要是我们在引入命名空间时没有正确引入它的DTD解析 ...

  4. nginx日志统计流量

    cat access.log |awk '{sum+=$10} END {print sum/1024/1024/1024}' $10是nginx字段bytes_sent 字段,根据自己的日志格式修改 ...

  5. Allegro PCB查看VIA孔的pad信息

    1.勾选下图选项 2.选中via孔,右键-->>>Edit 3.弹出Padatack Designer

  6. 使用Fiddler抓包拦截线上JS

    第三方教程:http://www.lcgod.com/atc_74 分六步即可: 1.左侧session列表中选中你想替换的一条请求 2.右侧,切换到AutoResponder,点击Add rules ...

  7. atom无法安装插件的解决方法

    atom通过setting中无法下载插件,通过apm也无法下载插件,可能是网络.config配置的问题,不好解决. 下面的方法全手动,基本属于万金油方法: 1,在atom的setting页面中点击op ...

  8. IMSDroid问题集

    1.IMSDroid切换摄像头后的接收方横屏显示.事实上非常多种情况下都会突然发现就横屏了.解决的方法就是切换摄像头时同一时候切换横竖屏显示 2.IMSDroid掉音问题:IMSDroid通话几分钟后 ...

  9. iOS swift 给MBProgressHUD添加分类

    MBProgressHUD在开发中经常会用到,今天把MBProgressHUD的方法拓展了一下,更加方便使用 1.可以实现gif图片的展示,使用时请替换test.gif 2.可以控制是否允许交互,如果 ...

  10. implicitly declaring function 'malloc' with type void *(unsigned long ) 错误 解决

    errror :   implicitly declaring function 'malloc' with type void *(unsigned long ) Be sure to includ ...