Yii2: updateAll with multi conditions

北战南征 提交于 2019-12-10 02:24:34

问题


How to update all records by my condition? (my code is not work)

$condition[] = ['>', 'position', $old_position];
$condition[] = ['<=', 'position', $new_position];
$condition[] = ['in', 'id', $ids];

Video::updateAll([
    'position' => new \yii\db\Expression('@a := @a + 1'),
], $condition);

回答1:


You forgot the operator, you should simply try :

$condition = ['and',
    ['>', 'position', $old_position],
    ['<=', 'position', $new_position],
    ['in', 'id', $ids],
];

Read more : http://www.yiiframework.com/doc-2.0/yii-db-query.html#where()-detail



来源:https://stackoverflow.com/questions/32477678/yii2-updateall-with-multi-conditions

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!