> ## 關聯預載入
> 描述:將N+1次查詢優化為兩次查詢,提高查詢性能,一對一關聯只需查詢一次,一對多關聯只需查詢兩次
```
// 一對一關聯預載入支持兩種方式:join:0和in:1
class User extends Model
{
public function profile()
{
// 設置預載入查詢方式為IN方式
return $this->hasOne('Profile')->setEagerlyType(1);
// 設置預載入查詢方式為JOIN方式
return $this->hasOne('Profile')->setEagerlyType(0);
}
}
// 沒有用到關聯預載入(查詢4次)
$list = User::all([1,2,3]); // 一次查詢 (id in (1,2,3)
foreach($list as $user){ // 三次查詢 (根據user_id查出profile)
// 獲取用戶關聯的profile模型數據
dump($user->profile);
}
// 關聯預載入方式(查詢2次)
$list = User::with('profile')->select([1,2,3]); (2次查詢,一:id in (1,2,3) 二:user_id in (1,2,3))
foreach($list as $user){
// 獲取用戶關聯的profile模型數據
dump($user->profile);
}
// 同樣的也可以使用get和all方法進行預載入,如
$list = User::all([1,2,3],'profile,book');
// 指定查詢的字段
$list = User::field('id,name')->with(['profile'=>function($query){$query->field('email,phone');}])->select([1,2,3]);
// 預載入多個關聯
$list = User::with('profile,book')->select([1,2,3]);
// 嵌套預載入(遠程一對多關聯)
$list = User::with('profile.phone')->select([1,2,3]);
foreach($list as $user){
// 獲取用戶關聯的phone模型
dump($user->profile->phone);
}
// 如果要獲取子模型關聯的多個子模型(可以傳入子模型的子模型數組)
$list = User::with(['profile'=>['phone','job','img']])->select([1,2,3]);
foreach($list as $user){
// 獲取用戶關聯
dump($user->profile->phone);
dump($user->profile->job);
dump($user->profile->img);
}
// 關聯預載入的方法名支持用小寫字母+下劃線定義
$list = User::with('userProfile,userBook')->select([1,2,3]);
等效??于
$list = User::with('user_profile,user_book')->select([1,2,3]);
```
- 運行環境需求
- tp5目錄結構
- 命令行生成代碼
- 路由
- 請求
- 獲取請求信息
- 超全局變量獲取
- 更改請求變量的值
- 判斷是否為某種請求類型
- 偽裝表單請求類型
- HTTP頭部信息
- 偽靜態
- 向請求對象中注入自定義的屬性和方法
- 簡單的傳參可以使用參數綁定
- 依賴注入(將對象注入方法作為參數)
- 將請求的數據進行緩存
- 控制器
- 一個控制器代碼示例
- 空控制器
- 資源控制器
- 模型
- 一個模型代碼示例
- 模型的四種調用方法
- 控制器中調用模型添加數據
- 控制器中調用模型更新數據
- 控制器中調用模型刪除數據
- 控制器中調用模型查詢數據
- 模型中使用聚合函數
- 獲取器
- 修改器
- 自動寫入時間戳
- 只讀字段
- 軟刪除
- 自動類型轉換
- 數據自動完成
- 查詢范圍
- 數組方式訪問和轉換為數組
- json序列化
- 模型的事件
- 關聯模型
- 一對一關聯
- 一對多關聯
- 遠程一對多(跨表關聯)
- 多對多關聯
- 多態關聯
- 關聯預載入N+1次查詢變2次
- 延遲預載入
- 關聯統計
- 視圖與模板
- 模板引擎配置
- 分配數據到模板
- 輸出替換
- 模板中輸出變量
- 模板中輸出系統變量(配置常量超全局)
- 模板中輸出請求信息
- 模板中使用php函數
- 輸出到模板中的變量指定默認值
- 模板中進行運算
- 原樣輸出代碼不解析
- 模版中注釋
- 模板布局與繼承
- 文件包含
- 內置標簽
- 循環輸出標簽
- 比較標簽
- 條件判斷標簽
- 引入資源文件(js-css)
- 使用原生php
- 在模板中定義變量和常量
- 助手函數
- 常用功能
- 表單驗證
- 驗證器的定義
- 自定義驗證規則
- 速查表
- 系統默認根命名空間
- 系統路徑常量
- 請求變量
- URL請求和信息方法