文档章节

Thinkphp5.0 的使用模型Model的获取器与修改器

o
 osc_4nmshwhm
发布于 2018/08/06 16:47
字数 881
阅读 9
收藏 0

精选30+云产品,助力企业轻松上云!>>>

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

 

o
粉丝 0
博文 500
码字总数 0
作品 0
私信 提问
加载中
请先登录后再评论。

暂无文章

如何防止单击按钮时对话框关闭 - How to prevent a dialog from closing when a button is clicked

问题: I have a dialog with EditText for input. 我有一个使用EditText输入的对话框。 When I click the "yes" button on dialog, it will validate the input and then close the dialog.......

富含淀粉
21分钟前
7
0
访问者模式Visitor

一 概述 场景:通常来说,用于封装数据所用到的pojo类,其只包含get、set,对应的业务逻辑是在Service上完成的;但如果出现多个pojo类都共用一套逻辑时,则应该考虑将逻辑进行抽象,不同类型...

小明不觉小
46分钟前
5
0
jQuery Ajax错误处理,显示自定义异常消息 - jQuery Ajax error handling, show custom exception messages

问题: Is there some way I can show custom exception messages as an alert in my jQuery AJAX error message? 有没有什么方法可以在我的jQuery AJAX错误消息中显示自定义异常消息作为警报...

法国红酒甜
51分钟前
28
0
告别传统机房:3D 机房数据可视化实现智能化与VR技术的新碰撞

前言 随着各行业对计算机依赖性的日益提高,计算机信息系统的发展使得作为其网络设备、主机服务器、数据存储设备、网络安全设备等核心设备存放地的计算机机房日益显现出它的重要地位,而机房...

xhload3d
昨天
51
0
spring源码解析-xml配置文件读取

整个 XML配置文件读取的大致流程如下: 通过继承自AbstractBeanDefinitionReader中的方法,来使用ResourLoader将资源文件路径转换为对应的Resource文件(读取资源文件并将其转为Resource) ...

wc_飞豆
昨天
22
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部