Yii2數據字段自動累加
- 2019 年 10 月 5 日
- 筆記
文章一般都有統計瀏覽次數的需求,一般小型項目的做法就是直接 update 數據庫中的某個字段。在 Yii 中怎麼實現呢?請往下看
實現
方式一
Yii2 中有這個 updateAllCounters
靜態方法,這種方式是最快並且最省事的實現方式,代碼示例如下:
Topic::updateAllCounters(['view_count' => 1], ['id' => $id]); // 實現的效果就是 view_count + 1,1根據你的需求可以是正數也可以是負數。
如果你的條件比較複雜你可以這樣寫:
Topic::updateAllCounters(['view_count' => 1], ['and', ['xxx' => 0, 'yyy' => 2], ['>', 'zzz', $time]);
如果你現在的需求是:更新一個字段的值,一個字段的值 +1,你可以試着用這種方式去實現:
Topic::updateAll( ['view_count' => new Expression('`view_count` + 1'), 'updated_at' => time()], ['id' => $id] );
PS:此處的 view_count
字段默認值切記不能設置為 null
。
Expression
是表達式的意思,可以實現更多特殊 SQL,想了解更多,可以去搜索一下文檔。
方式二
當然你還可以這樣去實現:
$model = Post::findOne($id); $model->updateCounters(['view_count' => 1]);