您好,登錄后才能下訂單哦!
Yii2數(shù)據(jù)字段怎么實現(xiàn)自動累加,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
實現(xiàn)
方式一
Yii2 中有這個 updateAllCounters
靜態(tài)方法,這種方式是最快并且最省事的實現(xiàn)方式,代碼示例如下:
Topic::updateAllCounters(['view_count' => 1], ['id' => $id]); // 實現(xiàn)的效果就是 view_count + 1,1根據(jù)你的需求可以是正數(shù)也可以是負數(shù)。
如果你的條件比較復雜你可以這樣寫:
Topic::updateAllCounters(['view_count' => 1], ['and', ['xxx' => 0, 'yyy' => 2], ['>', 'zzz', $time]);
如果你現(xiàn)在的需求是:更新一個字段的值,一個字段的值 +1,你可以試著用這種方式去實現(xiàn):
Topic::updateAll( ['view_count' => new Expression('`view_count` + 1'), 'updated_at' => time()], ['id' => $id] );
PS:此處的 view_count
字段默認值切記不能設置為 null
。
Expression
是表達式的意思,可以實現(xiàn)更多特殊 SQL,想了解更多,可以去搜索一下文檔。
方式二
當然你還可以這樣去實現(xiàn):
$model = Post::findOne($id); $model->updateCounters(['view_count' => 1]);
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業(yè)資訊頻道,感謝您對億速云的支持。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。