Я новичок в разработке Голанга.У меня есть 6 параметров для передачи в запрос с помощью Gorm.это запрос на выборку, поэтому на основе входного значения нам нужно отфильтровать значения.Итак, нам нужно динамически передавать фильтры в запрос.Я пытался, но не нашел решения.
func GetUsers (DB * gorm.DB, Offset int, Limit int, User uibackendmodels.UserDetails) (Users [] uibackendmodels.UserDetails, ошибка Err) {
query := "SELECT userid, username, nickname, email, mobile, location, status, roleids, trsids, brandids, languagecode, createdat, createdby, modified, modifiedby" +
" FROM users WHERE 1=1 "
if User.UserName != "" || User.NickName != "" {
nameQuery := "("
if User.UserName != "" {
nameQuery = nameQuery + " username LIKE " + "'" + User.UserName + "%'"
}
if User.NickName != "" && User.UserName != "" {
nameQuery = nameQuery + " OR nickname LIKE " + "'" + User.NickName + "%'"
} else if User.NickName != "" {
nameQuery = nameQuery + " nickname LIKE " + "'" + User.NickName + "%'"
}
query = query + " AND " + nameQuery + ")"
}
if User.BrandIDs != nil && len(User.BrandIDs) > 0 {
brandIds := "("
for i := range User.BrandIDs {
if len(User.BrandIDs) == (i + 1) {
brandIds = brandIds + "'" + User.BrandIDs[i] + "' = ANY (brandids) "
} else {
brandIds = brandIds + "'" + User.BrandIDs[i] + "' = ANY (brandids) OR "
}
}
query = query + " AND " + brandIds + ")"
}
if User.TRSIDs != nil && len(User.TRSIDs) > 0 {
trsIds := "("
for i := range User.TRSIDs {
if len(User.TRSIDs) == (i + 1) {
trsIds = trsIds + "'" + User.TRSIDs[i] + "' = ANY (trsids) "
} else {
trsIds = trsIds + "'" + User.TRSIDs[i] + "' = ANY (trsids) OR "
}
}
query = query + " AND " + trsIds + ")"
}
if User.RoleIDs != nil && len(User.RoleIDs) > 0 {
roleIds := "("
for i := range User.RoleIDs {
if len(User.RoleIDs) == (i + 1) {
roleIds = roleIds + strconv.FormatInt(int64(User.RoleIDs[i]), 10) + " = ANY (roleids) "
} else {
roleIds = roleIds + strconv.FormatInt(int64(User.RoleIDs[i]), 10) + " = ANY (roleids) OR "
}
}
query = query + " AND " + roleIds + ")"
}
if User.Status != "" {
query = query + " AND status = " + "'" + EnumToString(User.Status) + "'"
}
query = query + " AND status != 'deleted' ORDER BY modified desc LIMIT " + strconv.Itoa(Limit) + " OFFSET " + strconv.Itoa(Offset)
if err := DB.Raw(query).Scan(&Users).Error; err != nil {
return nil, err
}
return Users, nil
}
Мне нужно динамически добавить параметры в запрос выше.