具有多个条件的updateAll

具有多个条件的updateAll

本文介绍了Yii2:具有多个条件的updateAll的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

如何根据我的条件更新所有记录? (我的代码不起作用)

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);


推荐答案

您忘记了运算符,只需尝试:

You forgot the operator, you should simply try :

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

了解更多:
http://www.yiiframework.com/doc-2.0/yii-db-query.html#where()-detail

这篇关于Yii2:具有多个条件的updateAll的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

09-05 02:01