在model中使用 get+字段名+Attr,能够修改字段的返回值。php
数据库中性别保存为,0未知、1男、2女,查询时返回汉字:数据库
model:安全
//将性别的012修改成未知、男。女返回 public function getSexAttr($val){ switch($val){ case '1' : return '男'; case '2': return '女'; default: return '未知'; } } //格式化时间戳后返回 public function getAddtimeAttr($val){ if($val){ return date('Y-m-d H:i:s',$val); }else{ return $val; } }
controller:app
$res = TestUser::get(2); dump($res->toArray());//性别会被model转化 dump($res->getData());//返回原始数据
在model中使用 set+字段名+Attr,能够修改字段值,方便添加数据时使用。加密
示例,好比密码须要MD5加密:spa
model:code
//对密码字段加密以后存储 //第一个参数是密码 //第二个参数是添加的数据,可选 public function setPasswordAttr($val,$data){ if($val === '') { return $val; }else{ return md5($val.$data['email']); } }
model:blog
//添加和修改时,都会自动完成的字段 protected $auto = ['addtime']; public function setAddtimeAttr(){ return time(); }
model:md5
protected $insert = ['addtime']; public function setAddtimeAttr(){ return time(); }
model:get
protected $update = ['addtime']; public function setAddtimeAttr(){ return time(); }
在数据库配置文件database.php中,有一项:
// 自动写入时间戳字段
'auto_timestamp' => false,
若是开启,则会自动完成全部表的时间戳,可是不建议这样,只在须要的地方设置更安全。
例如对用户表的时间戳自动完成,就在User的model中设置:
<?php namespace app\index\model; use think\Model; class User extends Model{ //开启自动完成时间戳功能 protected $autoWriteTimestamp = true; //开启后, //添加数据时,默认自动完成的字段是:create_time和update_time。 //修改数据时,默认自动完成的字段是:update_time。 //若是数据库不是这两个字段,则会报错 //若是不想用这两个字段,能够进行以下修改 protected $createTime = 'addtime';//修改默认的添加时间字段 protected $updateTime = 'updtime';//修改默认的修改时间字段
protected $updateTime = false;//当不须要这个字段时设置为false
}
软删除:当删除条记录时,有时咱们须要假删除,只经过修改某个字段状态来标记记录已删除。
model:
<?php namespace app\index\model; use think\Model; use traits\model\SoftDelete;//引入软删除的类 class User extends Model{ //使用软删除 //删除时,默认更新的字段是delete_time use SoftDelete; //若是修改修改默认的字段名字 protected $deleteTime = 'deltime'; }
控制器:
$res = User::destroy(1);//软删除 //返回影响的行数 dump($res);
执行删除后,就会更新delete_time字段,若是update_time字段也开启了自动完成,也会更新update_time字段。
//获取全部数据,会过滤掉delete_time不为null的记录(即软删除的记录不会显示) //注意,delete_time字段默认值要设置为null,不能设置为0,不然0页会被视为软删除过的数据 $res = $model->select(); //若是须要获取包含软删除的数据,使用withTrashed(true)。 $res = User::withTrashed(true)->select(); //若是须要获取软删除过的数据 $res = User::onlyTrashed()->select(); //删除id是15的记录,若是开启软删除,会进行假删除 $res = User::destroy(15); //若是开启了软删除,须要真正地删除数据,不作软删除 //destory()第二个参数传递true $res = User::destroy(15,true); //delete()参数传递true $userData = User::get(15); $userData->delete(true);