44 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package queue
 | ||
| 
 | ||
| import (
 | ||
| 	"context"
 | ||
| 	"time"
 | ||
| 	"tyc-server/app/main/api/internal/svc"
 | ||
| 
 | ||
| 	"github.com/hibiken/asynq"
 | ||
| 	"github.com/zeromicro/go-zero/core/logx"
 | ||
| )
 | ||
| 
 | ||
| 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 {
 | ||
| 	now := time.Now().Format("2006-01-02 15:04:05")
 | ||
| 	logx.Infof("%s - 开始执行查询数据清理任务", now)
 | ||
| 
 | ||
| 	// 计算7天前的时间
 | ||
| 	sevenDaysAgo := time.Now().AddDate(0, 0, -7)
 | ||
| 
 | ||
| 	// 创建查询条件,排除product_id为4的记录
 | ||
| 	conditions := l.svcCtx.QueryModel.SelectBuilder().Where("product_id != ?", 4)
 | ||
| 
 | ||
| 	// 调用QueryModel删除7天前的数据,排除product_id为4的记录
 | ||
| 	result, err := l.svcCtx.QueryModel.DeleteBefore(ctx, sevenDaysAgo, conditions)
 | ||
| 	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
 | ||
| }
 |