神奇的bug之DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP自动更新失败

业务场景:

数据表中有一个update_time字段,设置为timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,使用模型中的update()或save()方法【以phalcon为例】,发现无法更新。

问题解析:

  1. 在数据库中更改数据,发现更新字段会更改,判定是代码中的问题。
  2. 使用sql原生语句,结果同上。
  3. 使用模型中的update()方法,发现不能更新。
public function test($field_name1,$field_name2){
	$model = LiveRoomBroadcast::findFirst([
		"conditions" => "field_name1=:field_name1: AND field_name2=:field_name2: AND is_delete=1",
		"bind" => [
			"field_name1" => $field_name1,
			"field_name2" => $field_name2
		]
	]);
	$model->is_delete = 0;
                    // $del_broadcast_model->update_time = null;
	$res = $model->update();
}
  1. 配置了sql跟踪后发现其语句为:
[Wed, 29 Dec 21 18:36:20 +0800][INFO] 
SELECT 
	`table_name`.`id`,
	`table_name`.`field_name1`, 
	`table_name`.`end_time`, 
	`table_name`.`field_name2`, 
	`table_name`.`create_time`, 
	`table_name`.`update_time`, 
	`table_name`.`is_delete` 
FROM `table_name` 
WHERE `table_name`.`field_name1` = :field_name1 
AND `table_name`.`field_name2` = :field_name2 
LIMIT :APL0
[Wed, 29 Dec 21 18:36:20 +0800][INFO] 
UPDATE `table_name` 
SET 
	`field_name1` = ?, 
	`end_time` = null, 
	`field_name2` = ?, 
	`create_time` = ?, 
	`update_time` = ?, 
	`is_delete` = ? 
WHERE `id` = ?
  1. 从此处可以看到,取出模型对象的时候,将该条数据的所有信息都取出来,而且在update的时候将所有的值都赋给update()方法,导致数据库中的update_time字段仍然为过去的时间。

解决方法:

第一种:在模型中设置动态更新

use Phalcon\Mvc\Model;

class Robots extends Model
{
    public function initialize()
    {
        $this->useDynamicUpdate(true);
    }
}

再查看sql语句,已经变成

[Thu, 30 Dec 21 09:15:32 +0800][INFO]
SELECT 		
	`table_name`.`id`, 
	`table_name`.`field_name1`, 
	`table_name`.`end_time`, 
	`table_name`.`field_name2`, 
	`table_name`.`create_time`, 
	`table_name`.`update_time`, 
	`table_name`.`is_delete` 
FROM `table_name` 
WHERE `table_name`.`field_name1` = :field_name1 
AND `table_name`.`field_name2` = :field_name2 
AND `table_name`.`is_delete` = 1 
LIMIT :APL0
[Thu, 30 Dec 21 09:15:32 +0800][INFO] 
UPDATE `table_name` 
SET `is_delete` = ? 
WHERE `id` = ?

第二种: 更新的时候设置update_time字段,此种方法只能在更新的时候用,而且当使用框架封装的软删除仍然会出现问题。

public function test($field_name1,$field_name2){
	$model = LiveRoomBroadcast::findFirst([
		"conditions" => "field_name1=:field_name1: AND field_name2=:field_name2: AND is_delete=1",
		"bind" => [
			"field_name1" => $field_name1,
			"field_name2" => $field_name2
		]
	]);
	$model->is_delete = 0;
    $model->update_time = null;//数据库中不能为空,会自动填入
    //$model->update_time = time();直接设置时间
	$res = $model->update();

以上为学习笔记,若有误请指教。

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值