# 查詢
本節內容
1. 條件查詢
2. F對象
3. Q對象
4. 聚合
5. 排序
6. 關聯查詢
[準備測試數據](TestDatas.html)
### 一、條件查詢
1. 調用`filter方法`:**模型類.objects.filter(模型類屬性名\_\_條件名=值)**
2. 返回包含查詢結果數據的`QuerySet`對象
**練習案例:**
1. 判等: exact
~~~
例:查詢id為1的員工
~~~
2. 模糊查詢: contains / endswith / startswith
~~~
例:查詢名字包含'馬'的員工
例:查詢名字以'軍'結尾的員工
~~~
3. 空查詢: isnull
~~~
例:查詢備注信息不為空的員工
~~~
4. 范圍查詢: in
~~~
例:查詢id編號為1或3或5的員工
~~~
5. 比較查詢: gt(greater than)、lt(less than)、gte、lte
~~~
例:查詢age大于30的員工
~~~
6. 日期查詢: year、month、day、week\_day、hour、minute、second
~~~
例:查詢2015年入職的員工
例:查詢2014年1月1日后入職的員工
~~~
[案例參考答案](ORM查詢.html)
### 二、F對象
之前的查詢都是對象屬性與常量值比較,如果要比較兩個屬性怎么做呢? 比如:`查詢語文分數大于數學分數的學生`
| 姓名 | 數學 | 語文 | 英語 |
| --- | --- | --- | --- |
| Tom | 95 | 90 | 95 |
| Jack | 95 | 90 | 95 |
| Rose | 90 | 92 | 98 |
1. F對象:**比較表中的兩個字段**,接收的參數為一個字符串
2. 用法:`F('屬性名')`
* 比如:`成績表.objects.filter(語文__gt=F('數學'))`
* 需要導包:`from django.db.models import F`
3. 案例
~~~
例:查詢年齡大于id的員工信息(無實際意義)
例:查詢年齡大于4倍id編號的員工信息(無實際意義)
~~~
[案例參考答案](ORM查詢.html)
### 三、Q對象
* 作用:**對查詢條件進行`與 或 非`(& | ~) 的邏輯操作**
* 用法: 先導入`from django.db.models import Q`
* 與: Q(查詢條件1) & Q(查詢條件2)
* 或: Q(查詢條件1) | Q(查詢條件2)
* 非: ~Q(查詢條件)
* 案例
~~~
例:查詢id大于3且年齡大于30的員工信息。
例:查詢id大于3或者年齡大于30的員工信息。
例:查詢id不等于3員工信息。
~~~
[案例參考答案](ORM查詢.html)
### 四、排序
* 作用: 對查詢結果進行排序,**默認為升序**
* 用法:
升序:**模型類.objects.order\_by('屬性名')**
降序:**模型類.objects.order\_by('-屬性名')**
* 示例:
~~~
例:查詢所有員工信息,按照id從大到小進行排序。
例:把id大于3的員工信息按年齡從大到小排序顯示
~~~
### 五、`aggregate`方法
* 作用: 聚合操作,對多行查詢結果中的一列進行操作,返回一個值
* 用法:**模型類.objects.aggregate(聚合類('屬性名'))**
* 常用聚合類有:Sum, Count, Max, Min, Avg等
* 返回值是一個字典, 格式:`{'屬性名__聚合函數': 值}`
* 使用時需要先導入聚合類:`from django.db.models import Sum, Count, Max, Min, Avg`
* 案例:
~~~
例:查詢所有員工的平均工資。
~~~
[案例參考答案](ORM查詢.html)
### 六、關聯查詢
假設在`一對多`關系中,一對應的類叫做`一類`,多對應的類叫做`多類`
一、通過`對象`進行關聯查詢
1. 由`一類對象`查詢`多類對象`:**`一類對象.多類名小寫_set.all()`**
2. 由`多類對象`查詢`一類對象`:**`多類對象.關聯屬性`**
3. 示例
~~~
# 查詢 “研發部” 的所有員工
d = Department.objects.get(name=‘研發部’)
d.employee_set.all() # 一查多
# 例:查詢 “趙小二” 所屬的部門信息
e = Employee.objects.get(name='趙小二')
e.department # 多查一
~~~
二、通過`模型類`實現上述兩個案例
* `一類名.objects.filter(多類名小寫__多類屬性名__條件名=值)`
* `多類名.objects.filter(關聯屬性__一類屬性名__條件名=值)`
實現參考:
~~~
Employee.objects.filter(department__name__exact='研發部')
Department.objects.filter(employee__name__exact='趙小二')
# 簡寫
Employee.objects.filter(department__name='研發部')
Department.objects.filter(employee__name='趙小二')
~~~
- 基礎
- 輸入輸出
- 常量變量
- 常量
- 變量
- 數據類型
- 簡單數據類型
- 整型
- 浮點型
- 復數
- 復雜數據類型
- 序列
- 通用操作
- 字符串
- 定義
- 方法
- 格式化
- 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