业务场景:
数据表中有一个update_time字段,设置为timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,使用模型中的update()或save()方法【以phalcon为例】,发现无法更新。
问题解析:
- 在数据库中更改数据,发现更新字段会更改,判定是代码中的问题。
- 使用sql原生语句,结果同上。
- 使用模型中的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();
}
- 配置了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` = ?
- 从此处可以看到,取出模型对象的时候,将该条数据的所有信息都取出来,而且在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();
以上为学习笔记,若有误请指教。