gorm 多条件搜索db处理问题
问题描述
if phone != "" {
db = db.Where("phone = ?", phone)
}
if userInfo.UserType == 1 && userInfo.AgentUserId > 0 {
db = db.Where("agent_user_id = ? or promoter_user_id = ?", userInfo.AgentUserId, userInfo.AgentUserId)
}
err = db.
Limit(pageSize).
Offset((page - 1) * pageSize).
Find(&ShopList).Error
if err != nil {
s.log.Errorf("获取提现列表错误:%v", err)
return nil, 0, v1.ErrorUnknownError("%v", "获取提现列表错误~")
}
err = db.Count(&total).Error
if err != nil {
s.log.Errorf("获取店铺总数错误:%v", err)
return nil, total, v1.ErrorUnknownError("%v", "获取店铺总数错误~")
}
比如这样,count会吧limit条件也会带上,因为是链式操作,作用到同一个对象上 尝试使用
DBBase := db
err = DBBase .Count(&total).Error
仍然互带上limit条件,因为db为指针类型,实际复制的是指针,所以无效
解决方法
方式一 count前置,limit后置
err = db.Count(&total).Error
if err != nil {
s.log.Errorf("获取店铺总数错误:%v", err)
return nil, total, v1.ErrorUnknownError("%v", "获取店铺总数错误~")
}
err = db.
Limit(pageSize).
Offset((page - 1) * pageSize).
Find(&ShopList).Error
if err != nil {
s.log.Errorf("获取提现列表错误:%v", err)
return nil, 0, v1.ErrorUnknownError("%v", "获取提现列表错误~")
}
方式二 limit,Offset 添加-1参数覆盖掉limit条件
err = db.
Limit(pageSize).
Offset((page - 1) * pageSize).
Find(&ShopList).Error
if err != nil {
s.log.Errorf("获取提现列表错误:%v", err)
return nil, 0, v1.ErrorUnknownError("%v", "获取提现列表错误~")
}
err = db.Limit(-1).Offset(-1).Count(&total).Error
if err != nil {
s.log.Errorf("获取店铺总数错误:%v", err)
return nil, total, v1.ErrorUnknownError("%v", "获取店铺总数错误~")
}
|