问题
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