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