我正在使用 Go 来设置我自己的 API。由于我如何编写代码来动态创建/应用查询过滤器,我现在有点卡住了。它有效,但我想知道是否有更好的方法来完成下面的场景。
例如,我有一个带有复选框的搜索页面(1 个用于电子邮件,1 个用于名称)来缩小搜索范围。
// If I checked the email, the query would be like this
query findOne() {
user(func: type(user)) @filter(eq(email, "john.doe@email.com")) {
name
email
age
home_address
}
}
// If name checkedbox is also checked, it would be like this
query findOne() {
user(func: type(user)) @filter(eq(email, "john") OR eq(name, "john")) {
name
email
age
home_address
}
}
这是我到目前为止得到的,我认为有更好的方法来做到这一点:
func (s *Service) GetUser(email, name string) (*Users, error) {
c := db.NewClient()
defer db.Close()
var u Users
var filter string
if email != "" && mobileNumber != "" {
filter = fmt.Sprintf(`eq(email, "%s") OR eq(mobileNumber, "%s")`, email, mobileNumber)
} else if email != "" && mobileNumber == "" {
filter = fmt.Sprintf(`eq(email, "%s")`, email)
} else if email == "" && mobileNumber != "" {
filter = fmt.Sprintf(`eq(mobileNumber, "%s")`, mobileNumber)
}
q := fmt.Sprintf(`query findOne() {
users(func: type("user")) @filter(%s) {
name
email
home_address
contact_number
}
}`, filter)
ctx := context.Background()
res, err := c.NewTxn().Query(ctx, q)
if err != nil {
return nil, err
}
if err = json.Unmarshal(res.Json, &u); err != nil {
return nil, err
}
return &u, nil
}
有没有更好的方法来做到这一点而不是创造长期条件?