| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 |
- package dept
- import (
- "context"
- "fmt"
- "strings"
- "github.com/zeromicro/go-zero/core/stores/cache"
- "github.com/zeromicro/go-zero/core/stores/sqlx"
- )
- var _ SysDeptModel = (*customSysDeptModel)(nil)
- type (
- SysDeptModel interface {
- sysDeptModel
- FindAll(ctx context.Context) ([]*SysDept, error)
- FindByParentId(ctx context.Context, parentId int64) ([]*SysDept, error)
- FindByPathPrefix(ctx context.Context, pathPrefix string) ([]*SysDept, error)
- }
- customSysDeptModel struct {
- *defaultSysDeptModel
- }
- )
- func NewSysDeptModel(conn sqlx.SqlConn, c cache.CacheConf, cachePrefix string, opts ...cache.Option) SysDeptModel {
- return &customSysDeptModel{
- defaultSysDeptModel: newSysDeptModel(conn, c, cachePrefix, opts...),
- }
- }
- func (m *customSysDeptModel) FindAll(ctx context.Context) ([]*SysDept, error) {
- var list []*SysDept
- query := fmt.Sprintf("SELECT %s FROM %s ORDER BY `sort` ASC, `id` ASC", sysDeptRows, m.table)
- if err := m.QueryRowsNoCacheCtx(ctx, &list, query); err != nil {
- return nil, err
- }
- return list, nil
- }
- func (m *customSysDeptModel) FindByParentId(ctx context.Context, parentId int64) ([]*SysDept, error) {
- var list []*SysDept
- query := fmt.Sprintf("SELECT %s FROM %s WHERE `parentId` = ? ORDER BY `sort` ASC, `id` ASC", sysDeptRows, m.table)
- if err := m.QueryRowsNoCacheCtx(ctx, &list, query, parentId); err != nil {
- return nil, err
- }
- return list, nil
- }
- func (m *customSysDeptModel) FindByPathPrefix(ctx context.Context, pathPrefix string) ([]*SysDept, error) {
- escaped := strings.NewReplacer("%", "\\%", "_", "\\_").Replace(pathPrefix)
- var list []*SysDept
- query := fmt.Sprintf("SELECT %s FROM %s WHERE `path` LIKE ? ORDER BY `sort` ASC, `id` ASC", sysDeptRows, m.table)
- if err := m.QueryRowsNoCacheCtx(ctx, &list, query, escaped+"%"); err != nil {
- return nil, err
- }
- return list, nil
- }
|