package skill import ( "ai-agent/workflow/consts/public" skillDto "ai-agent/workflow/model/dto/skill" "ai-agent/workflow/model/entity" "context" "gitea.redpowerfuture.com/red-future/common/db/gfdb" "github.com/gogf/gf/v2/frame/g" "github.com/gogf/gf/v2/util/gconv" ) var SkillUserDao = &skillUserDao{} type skillUserDao struct{} func (d *skillUserDao) Insert(ctx context.Context, req *skillDto.CreateSkillUserReq) (id int64, err error) { skillUser := new(entity.SkillUser) err = gconv.Struct(req, &skillUser) r, err := gfdb.DB(ctx, public.DbNameBlackDeacon).Model(ctx, public.TableNameSkillUser).Insert(&skillUser) if err != nil { return } return r.LastInsertId() } func (d *skillUserDao) Update(ctx context.Context, req *skillDto.UpdateSkillUserReq) (rows int64, err error) { r, err := gfdb.DB(ctx, public.DbNameBlackDeacon).Model(ctx, public.TableNameSkillUser).OmitEmpty().Data(&req).Where(entity.SkillUserCol.Id, req.Id).Update() if err != nil { return } return r.RowsAffected() } func (d *skillUserDao) Delete(ctx context.Context, req *skillDto.DeleteSkillUserReq) (rows int64, err error) { r, err := gfdb.DB(ctx, public.DbNameBlackDeacon).Model(ctx, public.TableNameSkillUser).Where(entity.SkillUserCol.Id, req.Id).Delete() if err != nil { return } return r.RowsAffected() } func (d *skillUserDao) Count(ctx context.Context, req *skillDto.GetSkillUserReq) (count int, err error) { count, err = gfdb.DB(ctx, public.DbNameBlackDeacon).Model(ctx, public.TableNameSkillUser).NoTenantId(ctx).OmitEmpty(). Where(entity.SkillUserCol.Name, req.Name). Where(entity.SkillUserCol.Creator, req.Creator). WhereNot(entity.SkillUserCol.Id, req.NotInId). Where(entity.SkillUserCol.Id, req.Id).Count() return } func (d *skillUserDao) Get(ctx context.Context, req *skillDto.GetSkillUserReq, fields ...string) (res *entity.SkillUser, err error) { r, err := gfdb.DB(ctx, public.DbNameBlackDeacon).Model(ctx, public.TableNameSkillUser).NoTenantId(ctx).OmitEmpty(). Where(entity.SkillUserCol.Id, req.Id). Where(entity.SkillUserCol.Name, req.Name). Where(entity.SkillUserCol.Creator, req.Creator). Fields(fields).One() if err != nil { return } err = r.Struct(&res) return } func (d *skillUserDao) List(ctx context.Context, req *skillDto.ListSkillUserReq, fields ...string) (res []*entity.SkillUser, total int, err error) { model := gfdb.DB(ctx, public.DbNameBlackDeacon).Model(ctx, public.TableNameSkillUser).NoTenantId(ctx).Fields(fields).OmitEmpty() model.Where(entity.SkillUserCol.Creator, req.Creator) if !g.IsEmpty(req.Keyword) { model.WhereLike(entity.SkillUserCol.Name, "%"+req.Keyword+"%") } model.OrderDesc(entity.SkillUserCol.CreatedAt) if req.Page != nil { model.Page(int(req.Page.PageNum), int(req.Page.PageSize)) } r, total, err := model.AllAndCount(false) if err != nil { return } err = r.Structs(&res) return }