广告位 |
thinkphp模型的数据字段
2021年9月25日 11:07编程 > 1948人已围观
简介 模型的数据字段和对应数据表的字段是对应的,默认会自动获取(包括字段类型),但自动获取会导致增加一次查询,因此你可以在模型中明确定义字段信息避免多一次查询的开销。...
模型的数据字段和对应数据表的字段是对应的,默认会自动获取(包括字段类型),但自动获取会导致增加一次查询,因此你可以在模型中明确定义字段信息避免多一次查询的开销。
<?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类型或者数据库的字段类型都可以,字段类型定义的作用主要用于查询的参数自动绑定类型。
时间字段尽量采用实际的数据库类型定义,便于时间查询的字段自动识别。如果是
json
类型直接定义为json
即可。
如果你没有定义schema
属性的话,可以在部署完成后运行如下指令。
php think optimize:schema
运行后会自动生成数据表的字段信息缓存。使用命令行缓存的优势是Db类的查询仍然有效。
字段类型
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
数据。
严格区分字段大小写
默认情况下,你的模型数据名称和数据表字段应该保持严格一致,也就是说区分大小写。
$user = User::find(1);echo $user->create_time; // 正确echo $user->createTime; // 错误
严格区分字段大小写的情况下,如果你的数据表字段是大写,模型获取的时候也必须使用大写。
如果你希望在获取模型数据的时候不区分大小写(前提是数据表的字段命名必须规范,即小写+下划线),可以设置模型的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']; // 错误
上一篇: thinkphp模型数据的更新操作
下一篇: thinkphp定义模型
广告位 |
相关文章
随机图文
-
降维打击,今年就业形势究竟有多难?
近日,武汉东湖高新区社会事务局对社区干事免笔试人员名单进行公示,24名高学历人才赫然在列,引人瞩目。 这24人中,有5名博士、19名硕士,其中博士的专业分别是环境科学、材料科学与工程、作物环境及生态、生物化学与分子生物学、行星地质与比较行星学。... -
不用找啦!你要的免费商用字体都在这里!
经常有人问我可以免费商用的字体有哪些?为此我整理出这一套免费字体合集,包含了中文和西文共13类100多款字体。可以满足大部分设计风格的需求。 中文分为:宋体、圆体和卡通体、书法体、手写体、黑体、艺术体; 西文分为:衬线体、无衬线体、哥特黑体、手写体和其他风格字体(运动科技、优雅时尚、活泼可爱)。... -
波多野结衣也站台区块链了?
黄,赌,毒,堪称世上最赚钱的行业。往前数数,哪位大佬的发家史没参杂上面这几样,靠着“没法说”的背景一路上位,最后完美洗白。 即使中国早就把这三个产业列为重要打击对象,可依旧没法彻底消灭,毕竟哪里有金钱哪里就有犯罪。... -
thinkphp模型数据的更新操作
和模型新增一样,更新操作同样也会经过修改器、自动完成以及模型事件等处理,并不等同于数据库的数据更新,而且更新方法和新增方法使用的是同一个方法,通常系统会自动判断需要新增还是更新数据。...