0

下面的更新查询在 phpmyadmin 中运行。正确更新所有行。

SET @bal = 0;
UPDATE banking SET bank_bal = @bal := @bal + (cr_amt - dr_amt) WHERE `bank_account_id` = 2

我在 yii 中尝试了上面的查询:

$update = Yii::app()->db->createCommand()
->update('banking', 
    array(
        'bank_bal'=>new CDbExpression("@bal := @bal + (cr_amt - dr_amt)")
    ),
    'bank_account_id=:id',
    array(':id'=>$acc)
);

将余额列更新为所有行的 0。我知道@bal 没有设置。我把这个 mysql 行 SET @bal = 0 放在哪里。任何人都可以提供帮助。

4

2 回答 2

0

在这个地方:

'bank_bal'=>new CDbExpression("@bal := @bal + (cr_amt - dr_amt)",array('@bal'=>$value))

希望这可以帮助

于 2013-10-02T08:42:29.750 回答
0

只需在更新查询之前创建单独的 sql 查询 (SET @bal = 0;)

于 2013-10-02T14:23:59.210 回答