> ## 关联预载入
> 描述:将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请求和信息方法