我爱自学

 找回密码
 会员注册

QQ登录

只需一步,快速开始

thinkphp5操作数据 Update数据成功 update_time时间戳未自动更新

最近用thinkphp开发了一个小站,遇到update更新数据表时,数据更新成功,但是update_time时间戳,没有自动更新。在此,分享入坑原因和解决方法。
如摘要所述,使用thinkphp5进行数据库操作, 配置模型时开启了Auto时间戳的功能。Create方法创建数据时,Create_time和Update_time同时插入相同数据。但是在编辑修改时,用update方法更新数据后,数据更新成功,但是update_time时间戳没有更新


入坑时源代码如下图所示:

thinkphp更新数据库 时间戳不自动更新

thinkphp更新数据库 时间戳不自动更新


解决方法:需要用模型的操作方法,更新数据库

ShopList::update([
   'id' => $id,//默认更新id等于$id的数据
   'status' => '-1'
]);

可以测试,通过dump打印更新的结果,是一个模型对象。也可以使用:

ShopList::update([
   'status' => '-1'
],[  'id' => $id]);


以上方法,重复刷新执行,结果都是一样。但实际上数据仅进行了1次更新,因此这个方面不好确认是否更新成功。

可以使用SAVE这个方法

$model = new ShopList;
$model->save([ 'status' => '-1'
],[  'id' => $id])

以上,就是小编遇到时间戳不更新原因和处理方法


点击阅读更多内容!
如果您觉得文章内容帮助到了您,不妨点点感兴趣的广告。感谢您的支持!

微信扫一扫打赏

上一篇: 常见Thinkphp控制器调用方法

下一篇: 无下一篇内容

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 会员注册

本版积分规则

手机版|小黑屋|我爱自学 ( 蜀ICP备19015358号-3 )

GMT+8, 2024-4-27 16:49 , Processed in 0.087200 second(s), 56 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

本站大部分教程是网站原创教程,一部分教程为我爱自学(http://www.5izixue.com)编辑收集整理。

如果您需要转载我爱自学网站教程,请注明“资料来源:我爱自学(5izixue)”字样并注明本站网址。

编辑收集整理的教程版权归原作者所有,本站只提供网友交流学习使用,请勿用于商业用途,如果该文章有任何侵犯您权益的地方,请联系我们(569705694@qq.com),我们将在第一时间进行处理!谢谢您的支持!

快速回复 返回顶部 返回列表