溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Yii2數(shù)據(jù)字段怎么實現(xiàn)自動累加

發(fā)布時間:2021-06-18 15:23:50 來源:億速云 閱讀:764 作者:Leah 欄目:大數(shù)據(jù)

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è)資訊頻道,感謝您對億速云的支持。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

yii
AI