微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

CakePHP使用记录ID更新多行,相同的模型

我想更新一个模型.我有这样的查询

UPDATE mymodels SET `myfield` = 100 WHERE `id`=12 OR `id`=13 OR `id`=14
// also the same:
UPDATE mymodels SET `myfield` = 100 WHERE `id` IN (12,13,14)

我试过这个:

$this->MyModel->updateall(
    // fields
    array('MyModel.myfield' => 100),// conditions
    array('MyModel.id' => 12)
);

但我需要更新20条不同的记录.
记录ID就像这个12,14 ….

解决方法

如果要更新的记录是顺序的,请尝试添加两个这样的条件

$this->MyModel->updateall(
    array('MyModel.myfield' => 100),// conditions
    array('MyModel.id >=' => 12,'MyModel.id <=' => 20)
);

如果id的索引之间没有关系,请尝试使用数组

$this->MyModel->updateall(
    array('MyModel.myfield' => 100),// conditions
    array('MyModel.id' => array(12,14...))
);

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐