sysProductModel.go 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. package product
  2. import (
  3. "context"
  4. "fmt"
  5. "github.com/zeromicro/go-zero/core/stores/cache"
  6. "github.com/zeromicro/go-zero/core/stores/sqlx"
  7. )
  8. var _ SysProductModel = (*customSysProductModel)(nil)
  9. type (
  10. SysProductModel interface {
  11. sysProductModel
  12. FindList(ctx context.Context, page, pageSize int64) ([]*SysProduct, int64, error)
  13. }
  14. customSysProductModel struct {
  15. *defaultSysProductModel
  16. }
  17. )
  18. func NewSysProductModel(conn sqlx.SqlConn, c cache.CacheConf, cachePrefix string, opts ...cache.Option) SysProductModel {
  19. return &customSysProductModel{
  20. defaultSysProductModel: newSysProductModel(conn, c, cachePrefix, opts...),
  21. }
  22. }
  23. func (m *customSysProductModel) FindList(ctx context.Context, page, pageSize int64) ([]*SysProduct, int64, error) {
  24. var total int64
  25. countQuery := fmt.Sprintf("SELECT COUNT(*) FROM %s", m.table)
  26. if err := m.QueryRowNoCacheCtx(ctx, &total, countQuery); err != nil {
  27. return nil, 0, err
  28. }
  29. var list []*SysProduct
  30. query := fmt.Sprintf("SELECT %s FROM %s ORDER BY id DESC LIMIT ?,?", sysProductRows, m.table)
  31. if err := m.QueryRowsNoCacheCtx(ctx, &list, query, (page-1)*pageSize, pageSize); err != nil {
  32. return nil, 0, err
  33. }
  34. return list, total, nil
  35. }