Как я могу добавить параметры запроса виртуально, используя gorm? - PullRequest
0 голосов
/ 25 июня 2019

Я новичок в разработке Голанга.У меня есть 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

}

Мне нужно динамически добавить параметры в запрос выше.

1 Ответ

0 голосов
/ 25 июня 2019

В GORM вы можете обрабатывать основные входные данные, обогащая Объект и передавая его функции, подобной этой:

// Would get the First user with Name="jinzhu" and Age="20"
db.Where(&User{Name: "jinzhu", Age: 20}).First(&user)

Всякий раз, когда вы не можете выразить часть своего выражения с помощью функций по умолчанию в GORM, вы можете использовать обычный SQL и метод Chaining:

// Would get the first User with Name="jinzhu" and id in (4,5,6,7)
ids := [4]int{4,5,6,7}
db.Where(&User{Name: "jinzhu"}).Where("id IN (?)", ids).First(&user)

Вы также можете связывать методы, используя переменные

base := db.Where(&User{Name: "jinzhu"})
if someThing {
    base = base.Where("id IN (?)", ids) // Adding this condition just if someThing is true
}
base.First(&user) // Query your results

Дополнительная информация о методе связывания

...