thinkphp-模型的自动时间戳和只读字段、数据类型和转换

7419次阅读 338人点赞 作者: WuBin 发布时间: 2024-04-25 10:16:09
扫码到手机查看

模型自动时间戳

如果你想全局开启,在config/database.php 中,找到auto_timestamp设置为true;

// 自动写入时间戳字段
    // true为自动识别类型 false关闭
    // 字符串则明确指定时间字段类型 支持 int timestamp datetime date
    'auto_timestamp'  => true,

比如我tp_user表这么写的sql语句

CREATE TABLE `tp_user`  (
  `id` mediumint(8) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '自动编号',
  `username` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
  `password` char(40) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
  `email` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
  `create_time` datetime(0) NOT NULL DEFAULT '1997-01-01 01:01:01' COMMENT '创建时间',
  `update_time` datetime(0) NOT NULL DEFAULT '1997-01-01 01:01:01' COMMENT '修改时间',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 302 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

其中create_time和update_time都设置了默认值

当我们开启全局自动写入时间戳的时候,当我们执行插入新数据时:

$user = new UserModel();
$user->username = '李白';
$user->password = '123';
$user->gender = '男';
$user->email = 'libai@163.com';
$user->price = 100;
$user->details = '123';
$user->uid = 1011;
$user->replace()->save();

数据表中的create_time和update_time字段就会自动更新为当天的时间。

当我给config/database.php中的auto_timestamp设置为false时,那么当我再次插入的时候,就不会自动更新为当天的时间了,而会采用其默认值1997。

如果你只想设置某一个模型开启,需要设置特有字段(当全局设置为false时)

在对应的模型文件User.php中

protected $autoWriteTimestamp = true;

这时,仅仅tp_user表执行操作时,会自动更新时间戳,而其他表则不受影响。

当然,还有一种方法,就是全局开启,单独关闭某个或某几个模型为false;(其实就是全局设置为false,个别模型中$autoWriteTimestamp设置为false)

自动时间戳开启后,会自动写入create_time 和update_time 两个字段;此时,它们的默认的类型是int,如果是时间类型,可以更改如下(datetime其实与默认的true没什么区别):
// config/database.php中
'auto_timestamp' => 'datetime', 
// 或单独的模型文件中
protected $autoWriteTimestamp = 'datetime';

都配置完毕后,当我们新增一条数据时,无须新增create_time 会自动写入时间;同理,当我们修改一条数据时,无须修改update_time 会自动更新时间;

自动时间戳只能在模型下有效,数据库方法不可以使用。

如果创建和修改时间戳不是默认定义的,也可以自定义;

比如有如下表:

idusernamecreate_atupdate_at
1wubin.work1987-*****2024-*****

在模型文件中:

protected $createTime = 'create_at';
protected $updateTime = 'update_at';

如果全局时间戳是true,而业务中只需要create_time 而不需要update_time,可以关闭它,在对应的模型中设置:

protected $updateTime = false;

关闭后,比如插入时会忽略update_time字段,而是采用其字段的默认值。

可以动态实现不修改update_time和create_time(当全局时间戳开启时)

在控制器,执行插入的操作时:

$user = new UserModel();
$user->username = '李白';
$user->password = '123';
$user->gender = '男';
$user->email = 'libai@163.com';
$user->price = 100;
$user->details = '123';
$user->uid = 1011;
$user->isAutoWriteTimestamp(false)->replace()->save();

链式添加isAutoWriteTimestamp(false)即可

模型只读字段

所谓的模型只读字段,指的就是新增之后,就不可以再修改的字段。

比如我们要设置username 和email 不允许被修改,如下:

控制器中,更新一条数据

// 首先找到一条
$user = UserModel::find(330);
// 然后执行修改
$user->username = '哈登';
$user->email = '111111@163.com';
$user->price = Db::raw('price + 1'); // 每次更新price自增1
$user->save();

然后在模型中设置只读字段为username和email,让这两个字段中的数据不随着更新而修改

 // 只读字段 修改时无法修改(只可以新增)
protected $readonly = ['username', 'email'];
设置只读字段之后,就算更新数据不修改也不会报错。

除了在模型端设置,也可以动态设置只读字段(无需在模型中设置)

在控制器中:

// 首先找到一条
$user = UserModel::find(330);
// // 然后执行修改
$user->username = '杜兰特';
$user->email = '111111@163.com';
$user->price = Db::raw('price + 1');
$user->readonly(['username', 'email'])->save();
只读字段只支持模型方式不支持数据库方式

模型的数据类型和转换

普通是将结果直接进行类型转换,比如:

$user = UserModel::find(20);
var_dump((boolean)$user->status);
var_dump((float)$user->price);

integer(整型)、float(浮点型)、boolean(布尔型)、array(数组)object(对象)、serialize(序列化)、json(json)、timestamp(时间戳)datetime(日期)

一般datetime都是字符串类型。

如果要模型自动在取值的时候就要对相应的字段完成数据类型的转换,需要在模型中进行设定:

  // 类型转换
    protected $type = [
        'status' => 'boolean',
        'price' => 'float',
        'create_time' => 'datetime:Y-m-d'
    ];

其中还可以对时间进行格式化处理。

废弃字段,当某个字段在开发项目版本升级中不再使用,可以设置为废弃字段,废弃字段,当某个字段在开发项目版本升级中不再使用,可以设置为废弃字段。查询就不会被查询到。

在模型中:

//设置废弃字段
protected $disuse = ['status', 'uid'];

设置后,在控制器中查询等,就会忽略这些字段,不显示其值。

点赞 支持一下 觉得不错?客官您就稍微鼓励一下吧!
关键词:thinkphp
推荐阅读
  • uniapp实现被浏览器唤起的功能

    当用户打开h5链接时候,点击打开app若用户在已经安装过app的情况下直接打开app,若未安装过跳到应用市场下载安装这个功能在实现上主要分为两种场景,从普通浏览器唤醒以及从微信唤醒。

    10049次阅读 659人点赞 发布时间: 2022-12-14 16:34:53 立即查看
  • Vue

    盘点Vue2和Vue3的10种组件通信方式

    Vue中组件通信方式有很多,其中Vue2和Vue3实现起来也会有很多差异;本文将通过选项式API组合式API以及setup三种不同实现方式全面介绍Vue2和Vue3的组件通信方式。

    4677次阅读 346人点赞 发布时间: 2022-08-19 09:40:16 立即查看
  • JS

    几个高级前端常用的API

    推荐4个前端开发中常用的高端API,分别是MutationObserver、IntersectionObserver、getComputedstyle、getBoundingClientRect、requ...

    14754次阅读 967人点赞 发布时间: 2021-11-11 09:39:54 立即查看
  • PHP

    【正则】一些常用的正则表达式总结

    在日常开发中,正则表达式是非常有用的,正则表达式在每个语言中都是可以使用的,他就跟JSON一样,是通用的。了解一些常用的正则表达式,能大大提高你的工作效率。

    13963次阅读 525人点赞 发布时间: 2021-10-09 15:58:58 立即查看
  • 【中文】免费可商用字体下载与考证

    65款免费、可商用、无任何限制中文字体打包下载,这些字体都是经过长期验证,经得住市场考验的,让您规避被无良厂商起诉的风险。

    12705次阅读 1023人点赞 发布时间: 2021-07-05 15:28:45 立即查看
  • Vue

    Vue3开发一个v-loading的自定义指令

    在vue3中实现一个自定义的指令,有助于我们简化开发,简化复用,通过一个指令的调用即可实现一些可高度复用的交互。

    16943次阅读 1357人点赞 发布时间: 2021-07-02 15:58:35 立即查看
  • JS

    关于手机上滚动穿透问题的解决

    当页面出现浮层的时候,滑动浮层的内容,正常情况下预期应该是浮层下边的内容不会滚动;然而事实并非如此。在PC上使用css即可解决,但是在手机端,情况就变的比较复杂,就需要禁止触摸事件才可以。

    15465次阅读 1257人点赞 发布时间: 2021-05-31 09:25:50 立即查看
  • Vue

    Vue+html2canvas截图空白的问题

    在使用vue做信网单页专题时,有海报生成的功能,这里推荐2个插件:一个是html2canvas,构造好DOM然后转canvas进行截图;另外使用vue-canvas-poster(这个截止到2021年3月...

    30556次阅读 2403人点赞 发布时间: 2021-03-02 09:04:51 立即查看
  • Vue

    vue-router4过度动画无效解决方案

    在初次使用vue3+vue-router4时候,先后遇到了过度动画transition进入和退出分别无效的情况,搜遍百度没没找到合适解决方法,包括vue-route4有一些API都进行了变化,以前的一些操...

    26529次阅读 2041人点赞 发布时间: 2021-02-23 13:37:20 立即查看
交流 收藏 目录