Thinkphp5.0框架使用模型Model的获取器、修改器、软删除数据操作示例


Posted in PHP onOctober 11, 2019

本文实例讲述了Thinkphp5.0框架使用模型Model的获取器、修改器、软删除数据操作。分享给大家供大家参考,具体如下:

一、获取器

在model中使用 get+字段名+Attr,可以修改字段的返回值。

数据库中性别保存为,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:

$res = TestUser::get(2);
dump($res->toArray());//性别会被model转化
dump($res->getData());//返回原始数据

二、模型修改器:

在model中使用 set+字段名+Attr,可以修改字段值,方便添加数据时使用。

示例,比如密码需要MD5加密:

model:

//对密码字段加密之后存储
//第一个参数是密码
//第二个参数是添加的数据,可选
public function setPasswordAttr($val,$data){
    if($val === '') {
      return $val;
    }else{
      return md5($val.$data['email']);
    }
}

三、自动完成:

model:

//添加和修改时,都会自动完成的字段
protected $auto = ['addtime'];
public function setAddtimeAttr(){
    return time();
}

三、添加数据时,自动完成:

model:

protected $insert = ['addtime'];
public function setAddtimeAttr(){
    return time();
}

四、修改数据时,自动完成:

model:

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);

希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。

PHP 相关文章推荐
PHP新手上路(五)
Oct 09 PHP
PHP4 与 MySQL 数据库操作函数详解
Dec 06 PHP
php中使用cookie来保存用户登录信息的实现代码
Mar 08 PHP
浅谈PHP与C#的值类型指向区别的详解
May 21 PHP
Yii使用find findAll查找出指定字段的实现方法
Sep 05 PHP
自己写的php中文截取函数mb_strlen和mb_substr
Feb 09 PHP
PHP时间戳格式全部汇总 (获取时间、时间戳)
Jun 13 PHP
php、java、android、ios通用的3des方法(推荐)
Sep 09 PHP
PHP利用Socket获取网站的SSL证书与公钥
Jun 18 PHP
如何直接访问php实例对象中的private属性详解
Oct 12 PHP
Laravel框架实现超简单的分页效果示例
Feb 08 PHP
php字符串截取函数mb_substr用法实例分析
Jun 25 PHP
laravel中数据显示方法(默认值和下拉option默认选中)
Oct 11 #PHP
Thinkphp5.0 框架使用模型Model添加、更新、删除数据操作详解
Oct 11 #PHP
基于Laravel(5.4版本)的基本增删改查操作方法
Oct 11 #PHP
解决Laravel 使用insert插入数据,字段created_at为0000的问题
Oct 11 #PHP
Thinkphp5.0 框架Model模型简单用法分析
Oct 11 #PHP
laravel 判断查询数据库返回值的例子
Oct 11 #PHP
PHP实现通过二维数组键值获取一维键名操作示例
Oct 11 #PHP
You might like
《PHP边学边教》(01.开篇――准备工作)
2006/12/13 PHP
php获取汉字首字母的函数
2013/11/07 PHP
PHP JSON格式的中文显示问题解决方法
2015/04/09 PHP
php实现常见图片格式的水印和缩略图制作(面向对象)
2016/06/15 PHP
详谈配置phpstorm完美支持Codeigniter(CI)代码自动完成(代码提示)
2017/04/07 PHP
PPK 谈 JavaScript 的 this 关键字 [翻译]
2009/09/29 Javascript
boxy基于jquery的弹出层对话框插件扩展应用 弹出层选择器
2010/11/21 Javascript
jQuery学习基础知识小结
2010/11/25 Javascript
nodejs实现黑名单中间件设计
2014/06/17 NodeJs
JQ技术实现注册页面带有校验密码强度
2015/07/27 Javascript
AngularJS实现在ng-Options加上index的解决方法
2016/11/03 Javascript
原生js验证简洁注册登录页面
2016/12/17 Javascript
JS Select下拉框(支持输入模糊查询)
2017/02/04 Javascript
推荐VSCode 上特别好用的 Vue 插件之vetur
2017/09/14 Javascript
在Create React App中使用CSS Modules的方法示例
2019/01/15 Javascript
vue中格式化时间过滤器代码实例
2019/04/17 Javascript
自定义javascript验证框架示例【附源码下载】
2019/05/31 Javascript
JS扁平化输出数组的2种方法解析
2019/09/17 Javascript
vue简单封装axios插件和接口的统一管理操作示例
2020/02/02 Javascript
详解实现vue的数据响应式原理
2021/01/20 Vue.js
[14:24]Optic Gaming vs PSG LGD BO3
2018/06/07 DOTA
python操作数据库之sqlite3打开数据库、删除、修改示例
2014/03/13 Python
使用Protocol Buffers的C语言拓展提速Python程序的示例
2015/04/16 Python
python中利用xml.dom模块解析xml的方法教程
2017/05/24 Python
Python Numpy库安装与基本操作示例
2019/01/08 Python
python GUI库图形界面开发之PyQt5窗口布局控件QStackedWidget详细使用方法
2020/02/27 Python
python如何写try语句
2020/07/14 Python
用css3实现当鼠标移进去时当前亮其他变灰效果
2014/04/08 HTML / CSS
荷兰手表网站:Watch2Day
2018/07/02 全球购物
读书演讲主持词
2014/03/18 职场文书
大学班级学风建设方案
2014/05/01 职场文书
2019年七夕情人节浪漫祝福语大全!
2019/08/08 职场文书
《刺客之王:C罗全景传记》:时代从来不会亏待手艺人
2019/11/28 职场文书
python实现大文本文件分割成多个小文件
2021/04/20 Python
java调用Restful接口的三种方法
2021/08/23 Java/Android
js面向对象编程OOP及函数式编程FP区别
2022/07/07 Javascript