## 模型字段
模型的数据字段和对应数据表的字段是对应的,默认会自动获取(包括字段类型),但自动获取会导致增加一次查询,因此你可以在模型中明确定义字段信息避免多一次查询的开销。
~~~
<?php
namespace app\model;
use think\Model;
class User extends Model
{
// 设置字段信息
protected $schema = [
'id' => 'int',
'name' => 'string',
'status' => 'int',
'score' => 'float',
'create_time' => 'datetime',
'update_time' => 'datetime',
];
}
~~~
> 字段类型的定义可以使用PHP类型或者数据库的字段类型都可以,字段类型定义的作用主要用于查询的参数自动绑定类型。
>[danger] 时间字段尽量采用实际的数据库类型定义,便于时间查询的字段自动识别。如果是`json`类型直接定义为`json`即可。
如果你没有定义`schema`属性的话,可以在部署完成后运行如下指令。
~~~cmd
php think optimize:schema
~~~
运行后会自动生成数据表的字段信息缓存。使用命令行缓存的优势是Db类的查询仍然有效。
> 需要在数据库配置中设置`fields_cache`为`true`才能生成缓存
## 字段类型
`schema`属性一旦定义,就必须定义完整的数据表字段类型。
如果你只希望对某个字段定义需要自动转换的类型,可以使用`type`属性,例如:
~~~
<?php
namespace app\model;
use think\Model;
class User extends Model
{
// 设置字段自动转换类型
protected $type = [
'score' => 'float',
];
}
~~~
`type`属性定义的不一定是实际的字段,也有可能是你的字段别名。
## 废弃字段
如果因为历史遗留问题 ,你的数据表存在很多的废弃字段,你可以在模型里面定义这些不再使用的字段。
~~~
<?php
namespace app\model;
use think\Model;
class User extends Model
{
// 设置废弃字段
protected $disuse = [ 'status', 'type' ];
}
~~~
在查询和写入的时候会忽略定义的`status`和`type`废弃字段。
## 获取数据
在模型外部获取数据的方法如下
~~~
$user = User::find(1);
echo $user->create_time;
echo $user->name;
~~~
由于模型类实现了`ArrayAccess`接口,所以可以当成数组使用。
~~~
$user = User::find(1);
echo $user['create_time'];
echo $user['name'];
~~~
如果你是在模型内部获取数据的话,需要改成:
~~~
$user = $this->find(1);
echo $user->getAttr('create_time');
echo $user->getAttr('name');
~~~
否则可能会出现意想不到的错误。
## 模型赋值
可以使用下面的代码给模型对象赋值
```
$user = new User();
$user->name = 'thinkphp';
$user->score = 100;
```
该方式赋值会自动执行模型的修改器,如果不希望执行修改器操作,可以使用
```
$data['name'] = 'thinkphp';
$data['score'] = 100;
$user = new User($data);
```
或者使用
```
$user = new User();
$data['name'] = 'thinkphp';
$data['score'] = 100;
$user->data($data);
```
`data`方法支持使用修改器
```
$user = new User();
$data['name'] = 'thinkphp';
$data['score'] = 100;
$user->data($data, true);
```
如果需要对数据进行过滤,可以使用
```
$user = new User();
$data['name'] = 'thinkphp';
$data['score'] = 100;
$user->data($data, true, ['name','score']);
```
表示只设置`data`数组的`name`和`score`数据。
> 注意:`data`方法会清空调用前设置的数据
以追加数据的方式赋值:
```
$user = new User();
$user->group_id = 1;
$data['name'] = 'thinkphp';
$data['score'] = 100;
$user->appendData($data); // 如果调用 data ,则清空group_id字段数据
```
> 可以通过传入第二个参数 true 来使用修改器 ,比如:appendData($data,true)
## 严格区分字段大小写
默认情况下,你的模型数据名称和数据表字段应该保持严格一致,也就是说区分大小写。
~~~
$user = User::find(1);
echo $user->create_time; // 正确
echo $user->createTime; // 错误
~~~
>[danger] 严格区分字段大小写的情况下,如果你的数据表字段是大写,模型获取的时候也必须使用大写。
如果你希望在获取模型数据的时候不区分大小写(前提是数据表的字段命名必须规范,即小写+下划线),可以设置模型的`strict`属性。
~~~
<?php
namespace app\model;
use think\Model;
class User extends Model
{
// 模型数据不区分大小写
protected $strict = false,
}
~~~
你现在可以使用
~~~
$user = User::find(1);
// 下面两种方式都有效
echo $user->createTime;
echo $user->create_time;
~~~
## 模型数据转驼峰
`V6.0.4+`版本开始,可以设置`convertNameToCamel`属性使得模型数据返回驼峰方式命名(前提也是数据表的字段命名必须规范,即小写+下划线)。
~~~
<?php
namespace app\model;
use think\Model;
class User extends Model
{
// 数据转换为驼峰命名
protected $convertNameToCamel = true,
}
~~~
然后在模型输出的时候可以直接使用驼峰命名的方式获取。
~~~
$user = User::find(1);
$data = $user->toArray();
echo $data['createTime']; // 正确
echo $user['create_time']; // 错误
~~~
- 序言
- 基础
- 安装
- 开发规范
- 目录结构
- 配置
- 架构
- 请求流程
- 架构总览
- 入口文件
- 多应用模式
- URL访问
- 容器和依赖注入
- 服务
- 门面
- 中间件
- 事件
- 路由
- 路由定义
- 变量规则
- 路由地址
- 路由参数
- 路由中间件
- 路由分组
- 资源路由
- 注解路由
- 路由绑定
- 域名路由
- MISS路由
- 跨域请求
- URL生成
- 控制器
- 控制器定义
- 基础控制器
- 空控制器
- 资源控制器
- 控制器中间件
- 请求
- 请求对象
- 请求信息
- 输入变量
- 请求类型
- HTTP头信息
- 伪静态
- 参数绑定
- 请求缓存
- 响应
- 响应输出
- 响应参数
- 重定向
- 文件下载
- 数据库
- 连接数据库
- 分布式数据库
- 查询构造器
- 查询数据
- 添加数据
- 更新数据
- 删除数据
- 查询表达式
- 链式操作
- where
- table
- alias
- field
- strict
- limit
- page
- order
- group
- having
- join
- union
- distinct
- lock
- cache
- cacheAlways
- comment
- fetchSql
- force
- partition
- failException
- sequence
- replace
- extra
- duplicate
- procedure
- 聚合查询
- 分页查询
- 时间查询
- 高级查询
- 视图查询
- JSON字段
- 子查询
- 原生查询
- 获取查询参数
- 查询事件
- 获取器
- 事务操作
- 存储过程
- 数据集
- 数据库驱动
- 模型
- 定义
- 模型字段
- 新增
- 更新
- 删除
- 查询
- 查询范围
- JSON字段
- 获取器
- 修改器
- 搜索器
- 数据集
- 自动时间戳
- 只读字段
- 软删除
- 类型转换
- 模型输出
- 模型事件
- 模型关联
- 一对一关联
- 一对多关联
- 远程一对多
- 远程一对一
- 多对多关联
- 多态关联
- 关联预载入
- 关联统计
- 关联输出
- 虚拟模型
- 视图
- 模板变量
- 视图过滤
- 模板渲染
- 模板引擎
- 视图驱动
- 错误和日志
- 异常处理
- 日志处理
- 调试
- 调试模式
- Trace调试
- SQL调试
- 变量调试
- 远程调试
- 验证
- 验证器
- 验证规则
- 错误信息
- 验证场景
- 路由验证
- 内置规则
- 表单令牌
- 注解验证
- 杂项
- 缓存
- Session
- Cookie
- 多语言
- 上传
- 命令行
- 启动内置服务器
- 查看版本
- 自动生成应用目录
- 创建类库文件
- 清除缓存文件
- 生成数据表字段缓存
- 生成路由映射缓存
- 输出路由定义
- 自定义指令
- Debug输出级别
- 扩展库
- 数据库迁移工具
- Workerman
- think助手工具库
- 验证码
- Swoole
- 附录
- 助手函数
- 升级指导
- 更新日志