qnc-server-tob/app/main/model/queryModel.go

60 lines
1.4 KiB
Go
Raw Normal View History

2025-01-10 00:09:25 +08:00
package model
import (
2025-04-08 21:53:45 +08:00
"context"
"fmt"
2025-04-11 13:10:17 +08:00
"qnc-server/common/globalkey"
2025-04-08 21:53:45 +08:00
"time"
2025-01-10 00:09:25 +08:00
"github.com/zeromicro/go-zero/core/stores/cache"
"github.com/zeromicro/go-zero/core/stores/sqlx"
)
var _ QueryModel = (*customQueryModel)(nil)
type (
// QueryModel is an interface to be customized, add more methods here,
// and implement the added methods in customQueryModel.
QueryModel interface {
queryModel
2025-04-08 21:53:45 +08:00
DeleteBefore(ctx context.Context, before time.Time) (int64, error)
2025-01-10 00:09:25 +08:00
}
customQueryModel struct {
*defaultQueryModel
}
)
// NewQueryModel returns a model for the database table.
func NewQueryModel(conn sqlx.SqlConn, c cache.CacheConf) QueryModel {
return &customQueryModel{
defaultQueryModel: newQueryModel(conn, c),
}
}
2025-04-08 21:53:45 +08:00
func (m *customQueryModel) DeleteBefore(ctx context.Context, before time.Time) (int64, error) {
var affected int64 = 0
// 使用事务处理批量删除
err := m.defaultQueryModel.Trans(ctx, func(ctx context.Context, session sqlx.Session) error {
query := fmt.Sprintf("DELETE FROM %s WHERE create_time < ? AND del_state = ?", m.defaultQueryModel.table)
result, err := session.ExecCtx(ctx, query, before.Format("2006-01-02 15:04:05"), globalkey.DelStateNo)
if err != nil {
return err
}
rows, err := result.RowsAffected()
if err != nil {
return err
}
affected = rows
return nil
})
if err != nil {
return 0, err
}
return affected, nil
}