🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
本实例演示tp5模型非常高效的功能 原来数据表结构如下 ![](https://box.kancloud.cn/2016-08-25_57be99bc07783.png) 存储数据如下 ![](https://box.kancloud.cn/2016-08-25_57be99bc2108f.png) 如上图,ip字段,ctime,utime采用了转换成int进行存储,方便排序,查找。但直接看表中数据,并不直观,类以这类表,利用model模型,能够方便的解决数据自动转换问题 sys_log表定义model如下 ~~~ <?php namespace app\common\model; use think\Model; use think\Validate; // http://ihavenolimitations.xyz/zmwtp/tp5/145712 model配置 class Log extends Model { protected $table = 'sys_log'; protected $auto = [ 'ip','utime']; //自动 完成字段 每次写入都执行 protected $insert = ['ctime','status'=>0,'type'=>'sys']; //插入数据 protected $update = []; //更新数据时 // 定义时间戳字段名 protected $autoWriteTimestamp = true; //支持默认两个字段,详见说明 protected $createTime = 'ctime'; protected $updateTime = 'utime'; // protected $autoTimeField = ['ctime']; protected $dateFormat = 'Y-m-d H:i:s'; //写入日期格式 //定义字段输出格式 protected $type = [ 'ctime' => 'timestamp:Y-m-d H:i:s', 'utime' => 'timestamp:Y-m-d H:i:s', ]; //验证 protected $rules = [ ['level','number|between:1,9','告警级别有误|级别必须是1~9级'], ['status','number|between:0,1','状态|状态必须是0~1'], ['message','require','信息必须'], ['ip','ip','IP地址有误'] ]; //自定义初始化 protected static function init() { //TODO:自定义的初始化 } //获取时自动处理字段转换 public function getLevelAttr($value){ $Level = [ 0=>'log', 1=>'error', 2=>'notice', 3=>'info', 4=>'debug' ]; return $Level[$value]; } //获取时自动处理字段转换 public function getIpAttr($value){ return long2ip($value); } //写入时自动处理 public function setIpAttr($value){ return ip2long(request()->ip()); } //验证访问是否有效 public function write($data){ $validate = new Validate($this->rules); if ($validate->check($data)){ return $this->data($data)->allowField(['message','level','status'])->save(); }else{ return $validate->getError(); } } public function scopeGetLast($query){ $query->order('ctime','desc'); } } ~~~ 写入数据 ~~~ $Log = model('Log','model'); // return $Log->where('id<781')->delete(); $data = [ 'message' =>'sdf', 'status'=>1, //'ip'=>'192.168.0.26', //系统自动添加 'level'=>4, //'ctime'=>"2016-08-04 15:00", ]; return $Log->write($data); ~~~ 如上,写入时,model已经定义好,会对ip,ctime,utime字段进行转换,注意,ctime,utime,model中已定义为自动添加 读取数据 ~~~ $Log = model('Log','model'); return dump(modelo2array($Log->select())); ~~~ 获取结果如下图 红色字段,已自动进行转换 ![](https://box.kancloud.cn/2016-08-25_57be99bc3cdf0.png) 附件上modelo2array()函数如下 ~~~ /* * 将model查询对像转换为数组数据 * */ function modelo2array($object){ $data = []; foreach($object as $key=>$rowO){ $data[$key] = $rowO->toArray(); } return $data; } ~~~