From a1fb6b1c02bc2c9ad2602bedc5bfd04e80a74670 Mon Sep 17 00:00:00 2001 From: lijikun Date: Fri, 3 Jan 2025 19:42:29 +0800 Subject: [PATCH] =?UTF-8?q?1=E6=9C=883=E6=97=A5=E6=99=9A=20=E4=BF=AE?= =?UTF-8?q?=E6=94=B9=E4=BA=86=E6=9F=A5=E8=AF=A2=E6=8B=A5=E6=9C=89=E5=8D=A1?= =?UTF-8?q?=E5=88=B8=E7=9A=84=E7=94=A8=E6=88=B7=E5=88=97=E8=A1=A8=E7=9A=84?= =?UTF-8?q?=E7=AE=97=E6=B3=95=E8=AE=BE=E8=AE=A1,=E6=9D=A1=E4=BB=B6?= =?UTF-8?q?=E6=9F=A5=E8=AF=A2=E4=B9=9F=E8=83=BD=E5=88=86=E9=A1=B5=E8=BF=9B?= =?UTF-8?q?=E8=A1=8C?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- api/v1/couponusers/couponUsers.go | 1 + internal/logic/couponusers/couponUsers.go | 95 ++++++++++--------------------- 2 files changed, 32 insertions(+), 64 deletions(-) diff --git a/api/v1/couponusers/couponUsers.go b/api/v1/couponusers/couponUsers.go index 720f00c..92f7f0e 100644 --- a/api/v1/couponusers/couponUsers.go +++ b/api/v1/couponusers/couponUsers.go @@ -15,6 +15,7 @@ type GetCouponUsersRes struct { Jwcode int `json:"jwcode" dc:"精网号"` DeptName string `json:"deptName" dc:"部门"` ShopName string `json:"shopName" dc:"门店"` + Total int `json:"total" dc:"总数"` } // DelCouponUserByJwcodeReq 删除卡券用户 diff --git a/internal/logic/couponusers/couponUsers.go b/internal/logic/couponusers/couponUsers.go index 6c49180..4ab67b0 100644 --- a/internal/logic/couponusers/couponUsers.go +++ b/internal/logic/couponusers/couponUsers.go @@ -26,74 +26,41 @@ func init() { // 根据优惠券id查看拥有优惠券的用户 func (s *sCouponUsers) GetCouponUsersByCondition(ctx context.Context, couponId, jwcode int, name string, pageNo, pageSize int) (users []couponusers.GetCouponUsersRes, err error) { - //没有条件查询时,分页 - if jwcode == 0 && name == "" { - /*查询所有数据*/ - //在coupon_users中查询出对应的jwcode - err = dao.CouponUsers.Ctx(ctx).Fields("jwcode"). - Where("coupon_id = ", couponId).Page(pageNo, pageSize).Scan(&users) - if err != nil { - return nil, errors.New("根据卡券id搜索jwcode失败") - } - //根据jwcode查询用户信息 - for i, userInfo := range users { - err = dao.MemberInfo.Ctx(ctx).Fields("jwcode", "name", "deptName", "shopName"). - Where("jwcode = ?", userInfo.Jwcode).Scan(&users[i]) - if err != nil { - return nil, errors.New("根据jwcode搜索用户信息失败") - } - } - /*查询所有数据*/ + db := dao.CouponUsers.Ctx(ctx) - return users, err - } else { //有条件查询时,不在分页,全查后筛选 + //基于量表JOIN查询 + db = db.As("cu").InnerJoin("member_info mi", "cu.jwcode = mi.jwcode"). + Where("cu.coupon_id = ?", couponId) - /*查询所有数据*/ - //在coupon_users中查询出对应的jwcode - err = dao.CouponUsers.Ctx(ctx).Fields("jwcode"). - Where("coupon_id = ", couponId).Scan(&users) - if err != nil { - return nil, errors.New("根据卡券id搜索jwcode失败") - } - //根据jwcode查询用户信息 - for i, userInfo := range users { - err = dao.MemberInfo.Ctx(ctx).Fields("jwcode", "name", "deptName", "shopName"). - Where("jwcode = ?", userInfo.Jwcode).Scan(&users[i]) - if err != nil { - return nil, errors.New("根据jwcode搜索用户信息失败") - } - } - /*查询所有数据*/ - - //条件查询 - if jwcode != 0 && name == "" { - var result []couponusers.GetCouponUsersRes - for _, user := range users { - if user.Jwcode == jwcode { - result = append(result, user) - } - } - return result, err - } else if jwcode == 0 && name != "" { - var result []couponusers.GetCouponUsersRes - for _, user := range users { - if strings.Contains(user.Name, name) { - result = append(result, user) - } - } - return result, err - } else if jwcode != 0 && name != "" { - var result []couponusers.GetCouponUsersRes - for _, user := range users { - if user.Jwcode == jwcode && strings.Contains(user.Name, name) { - result = append(result, user) - } - } - return result, err - } + //如果jwcode条件存在 + if jwcode != 0 { + db = db.Where("cu.jwcode = ?", jwcode) + } - return users, err + //如果name条件存在 + if name != "" { + db = db.Where("mi.name like ?", "%"+name+"%") + } + + //查询总数 + total, err := db.Count() + if err != nil { + return nil, errors.New("查询总数失败") } + + //查询数据(分页) + err = db.Fields("mi.jwcode, mi.name, mi.deptName, mi.shopName"). + Page(pageNo, pageSize).Scan(&users) + if err != nil { + return nil, errors.New("查询数据失败") + } + + //设置总数 + for i := range users { + users[i].Total = total + } + + return users, err } // 根据jwcode,优惠券id删除用户