| 1234567891011121314151617181920212223242526272829303132333435363738394041424344 |
- package product
- import (
- "context"
- "fmt"
- "github.com/zeromicro/go-zero/core/stores/cache"
- "github.com/zeromicro/go-zero/core/stores/sqlx"
- )
- var _ SysProductModel = (*customSysProductModel)(nil)
- type (
- SysProductModel interface {
- sysProductModel
- FindList(ctx context.Context, page, pageSize int64) ([]*SysProduct, int64, error)
- }
- customSysProductModel struct {
- *defaultSysProductModel
- }
- )
- func NewSysProductModel(conn sqlx.SqlConn, c cache.CacheConf, cachePrefix string, opts ...cache.Option) SysProductModel {
- return &customSysProductModel{
- defaultSysProductModel: newSysProductModel(conn, c, cachePrefix, opts...),
- }
- }
- func (m *customSysProductModel) FindList(ctx context.Context, page, pageSize int64) ([]*SysProduct, int64, error) {
- var total int64
- countQuery := fmt.Sprintf("SELECT COUNT(*) FROM %s", m.table)
- if err := m.QueryRowNoCacheCtx(ctx, &total, countQuery); err != nil {
- return nil, 0, err
- }
- var list []*SysProduct
- query := fmt.Sprintf("SELECT %s FROM %s ORDER BY id DESC LIMIT ?,?", sysProductRows, m.table)
- if err := m.QueryRowsNoCacheCtx(ctx, &list, query, (page-1)*pageSize, pageSize); err != nil {
- return nil, 0, err
- }
- return list, total, nil
- }
|