tyc-server/app/main/api/internal/queue/cleanQueryData.go

44 lines
1.2 KiB
Go
Raw Normal View History

package queue
import (
"context"
2025-04-09 17:27:40 +08:00
"time"
2025-04-27 12:17:18 +08:00
"tyc-server/app/main/api/internal/svc"
2025-04-09 15:58:06 +08:00
"github.com/hibiken/asynq"
2025-04-09 17:27:40 +08:00
"github.com/zeromicro/go-zero/core/logx"
)
2025-04-09 17:27:40 +08:00
const TASKTIME = "0 3 * * *"
type CleanQueryDataHandler struct {
svcCtx *svc.ServiceContext
}
func NewCleanQueryDataHandler(svcCtx *svc.ServiceContext) *CleanQueryDataHandler {
return &CleanQueryDataHandler{
svcCtx: svcCtx,
}
}
func (l *CleanQueryDataHandler) ProcessTask(ctx context.Context, t *asynq.Task) error {
2025-04-09 17:27:40 +08:00
now := time.Now().Format("2006-01-02 15:04:05")
logx.Infof("%s - 开始执行查询数据清理任务", now)
2025-01-18 22:34:27 +08:00
2025-04-24 13:59:33 +08:00
// 计算7天前的时间
sevenDaysAgo := time.Now().AddDate(0, 0, -7)
2025-04-09 17:27:40 +08:00
2025-04-13 11:09:42 +08:00
// 创建查询条件排除product_id为4的记录
conditions := l.svcCtx.QueryModel.SelectBuilder().Where("product_id != ?", 4)
2025-04-24 13:59:33 +08:00
// 调用QueryModel删除7天前的数据排除product_id为4的记录
result, err := l.svcCtx.QueryModel.DeleteBefore(ctx, sevenDaysAgo, conditions)
2025-04-09 17:27:40 +08:00
if err != nil {
logx.Errorf("%s - 清理查询数据失败: %v", time.Now().Format("2006-01-02 15:04:05"), err)
return err
}
logx.Infof("%s - 查询数据清理完成,共删除 %d 条记录", time.Now().Format("2006-01-02 15:04:05"), result)
return nil
}