您好,登錄后才能下訂單哦!
Yii2數據字段怎么實現自動累加,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
實現
方式一
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]);
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。