admin管理员组文章数量:1612098
业务场景:
数据表中有一个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();
以上为学习笔记,若有误请指教。
本文标签: 自动更新神奇BugDefaultCURRENTTIMESTAMP
版权声明:本文标题:神奇的bug之DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP自动更新失败 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:https://www.elefans.com/dianzi/1728626772a1166592.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论