🐛 Trying fix views count

This commit is contained in:
LittleSheep 2025-02-17 17:58:26 +08:00
parent 3a4948d590
commit 12ffcb7c5b

View File

@ -1,9 +1,13 @@
package services package services
import ( import (
"fmt"
"git.solsynth.dev/hypernet/interactive/pkg/internal/database" "git.solsynth.dev/hypernet/interactive/pkg/internal/database"
"git.solsynth.dev/hypernet/interactive/pkg/internal/models" "git.solsynth.dev/hypernet/interactive/pkg/internal/models"
"github.com/samber/lo"
"gorm.io/gorm" "gorm.io/gorm"
"gorm.io/gorm/clause"
) )
var postViewQueue []models.PostView var postViewQueue []models.PostView
@ -35,7 +39,10 @@ func FlushPostViews() {
for _, item := range workingQueue { for _, item := range workingQueue {
updateRequiredPost[item.PostID] = true updateRequiredPost[item.PostID] = true
} }
_ = database.C.CreateInBatches(workingQueue, 1000).Error workingQueue = lo.UniqBy(workingQueue, func(item models.PostView) string {
return fmt.Sprintf("%d:%d", item.PostID, item.AccountID)
})
_ = database.C.Clauses(clause.OnConflict{DoNothing: true}).CreateInBatches(workingQueue, 1000).Error
for k := range updateRequiredPost { for k := range updateRequiredPost {
var count int64 var count int64
if err := database.C.Model(&models.PostView{}).Where("post_id = ?", k).Count(&count).Error; err != nil { if err := database.C.Model(&models.PostView{}).Where("post_id = ?", k).Count(&count).Error; err != nil {