# 查询集`QuerySet`
## 一、基本使用
**1)**当调用模型管理器的`all`,`filter`,`exclude`,`order_by`等方法时,返回的是一个`QuerySet`对象,**表示从数据库查询到的数据集合**;
| objects管理器中的方法 | 返回类型 | 作用 |
| --- | --- | --- |
| 模型类.objects.all() | QuerySet | 查询所有的对象 |
| 模型类.objects.filter() | QuerySet | 查询满足条件的对象 |
| 模型类.objects.exclude() | QuerySet | 查询不满条件的对象 |
| 模型类.objects.order\_by() | QuerySet | 对查询结果集进行排序 |
**2)**`QuerySet`提供的方法
| `QuerySet`方法 | 返回类型 | 作用 |
| --- | --- | --- |
| get() | 模型对象 | **查询一个对象,且只能有一个**:
如果查到多条数据,则报:`MultipleObjectsReturned`
如果查询不到数据,则报:`DoesNotExist` |
| all() | QuerySet | 查询所有的对象 |
| count() | 数字 | 查询总共有多少条数据 |
| filter() | QuerySet | 查询满足条件的对象 |
| exclude() | QuerySet | 查询不满条件的对象 |
| order\_by() | QuerySet | 对查询结果集进行排序 |
| aggregate() | 字典,例如:
{'salary\_\_avg': 9500.0} | 进行聚合操作`Sum, Count, Max, Min, Avg` |
| exists() | 布尔型 | True表示有查询集中有数据,否则没有 |
链式写法:`Employee.objects.filter(id__gt=3).order_by('-age')`
**3)**支持**下标**和**切片**操作
1. `query_set[0]`:取出查询集中的第一条数据,不存在会抛`IndexError`异常
2. `query_set[0:2]`:切片操作得到另一个新的`QuerySet`
3. **注意:下标不能为负数**
## 二、查询集两大特性
**1\. 惰性查询**
* 创建查询集时不会访问数据库,操作查询集中的数据时才会访问;
* 操作查询集指**下标、切片、迭代操作,与if合用**等
~~~
# 得到查询集,不会访问数据库
query_set = Department.objects.all()
# 此时才访问数据库
print(query_set[0])
~~~
**2\. 缓存功能**
1. 当遍历(迭代)访问查询集**所有数据**,会缓存查询集所有数据,当再次操作该查询集中的数据时,将会使用缓存;
~~~
# 创建查询集
query_set = Department.objects.all()
# 会查询数据库
[dep.name for dep in query_set]
# 使用缓存,不再查数据库
[dep.name for dep in query_set]
~~~
2. 如果只是访问查询集**部分数据**(下标或切片)不会缓存
~~~
# 创建查询集
query_set = Department.objects.all()
# 会查询数据库
query_set[0]
# 会查询数据库
query_set[0]
~~~
- 基础
- 输入输出
- 常量变量
- 常量
- 变量
- 数据类型
- 简单数据类型
- 整型
- 浮点型
- 复数
- 复杂数据类型
- 序列
- 通用操作
- 字符串
- 定义
- 方法
- 格式化
- eval
- range
- capitalize
- count
- 格式化
- list
- 定义
- 方法
- tuple
- 定义
- 特点
- 方法
- dict
- 定义
- set
- 定义
- 类型转换
- 函数
- 定义
- 参数
- 函数变量
- 多返回值
- 作用域
- 函数嵌套
- 匿名函数
- 面向对象
- 类
- 对象
- 封装
- 私有
- property
- 类属性和实例属性
- 实例方法、静态方法和类方法
- 继承
- 多态
- 接口
- 设计原则
- 开放/封闭原则
- 控制反转原则
- 接口隔离原则
- 单一职责原则
- 替换原则
- 魔法方法
- 构造方法
- 析构方法
- 静态方法
- doc
- call
- dict
- str
- 异常
- with
- 提高
- 深浅拷贝
- 闭包
- 装饰器
- 正则表达式
- 单个字符
- 多个字符
- 开头结尾
- 分组
- 高级语法
- 网络编程
- 多任务
- 线程
- 创建线程
- 主线程等待
- 共享全局变量
- 传递参数
- 进程
- 创建
- 进程间通信
- 协程
- 数据库
- SQL
- 安装
- 备份
- 查询
- 消除重复行
- 分组
- 字查询
- Python 中操作 MySQL
- 设计模式
- 简介
- 三大类
- 创建型
- 单例
- 常用模块
- 导入模块
- 系统内置
- os
- time
- math
- help
- logging
- 格式
- 输出到控制台
- 输出到文件
- 两个都输出
- 三方模块
- Tesseract
- redis
- 安装
- selenium
- Selenium
- PhantomJS
- Chromedriver
- turtle
- 五角星
- 正方体
- urllib3
- http请求
- Requests
- 基本使用
- 发送请求
- cookies
- 代理
- Django
- 框架介绍
- 项目搭建
- 项目配置
- 路由
- 项目urls.py
- 应用urls.py
- 控制器
- request
- response
- Cookie
- Session
- views
- Models
- 数据库
- ORM
- 配置和迁移
- 模型类
- 模型管理器
- 增删改
- 查
- 查询集
- Mysql日志
- 自定义模型管理器
- 中间件
- scrapy
- 工作原理
- 创建项目
- spider
- items
- pipeline
- settings
- logging
- 小例子
- 果壳网
- 人人网登陆
- 腾讯招聘
- 创建模块
- 网络爬虫
- 基础知识
- 爬虫的用途
- robots协议
- http和https
- 常见请求头
- 状态码
- 字符串
- requests
- 简介
- 发送请求
- response
- 小技巧
- 代理
- cookie和session
- Fiddler
- 数据提取
- 数据分类
- json
- 正则
- xpath
- lxml
- 自动化运维
- Shell
- 开发规范
- 注释
- 脚本执行
- 变量
- 表达式
- 测试语句
- 条件表达式
- 逻辑表达式
- 文件表达式
- 数值操作符
- 字符串比较
- 计算表达式
- 常见符号
- 重定向符号
- 管道符
- 其他符号
- 常见命令
- grep
- sed
- awk
- find
- 流程控制
- if