无法使用golang从数据存储区获取基于struct值的记录

问题描述 投票:2回答:1

我正在为搜索功能编写服务。当我在正文中传递值以获取特定记录时,我无法根据结构值获取它。例如:电话号码或用户名

EDIT1

type PatientData struct {
    ID            int64    datastore:"-"
    FirstName     string   json:"firstname,omitempty"
    LastName      string   json:"lastname,omitempty"
    UserName      string   json:"username,omitempty"
    Phone         string   json:"phone,omitempty"     
}

我想基于用户名或电话获取完整的结构值。以下是我的代码:

func searchValue (res http.ResponseWriter, req *http.Request){

    log.Printf("%#v Getting values url - x ", "called search")

    patient := &PatientData{}
    if err := json.NewDecoder(req.Body).Decode(patient); err != nil {
        panic(err)
    }
    ctx := appengine.NewContext(req)
    ctx, err := appengine.Namespace(ctx, NAMESPACENAME)
    if err != nil {
        panic(err)
    }

    m := patient.Phone
    i, err := strconv.ParseInt(m, 10, 64)
    log.Printf("%#v Getting values m ", m)
    log.Printf("%#v Getting values url -yyy ",i)

    key := datastore.NewKey(ctx, "Patient","" , i, nil)
    log.Printf("%#v Getting values url - key ", key)
    err = datastore.Get(ctx, key, patient)
    if err := json.NewEncoder(res).Encode(patient); err != nil {
        panic(err)
    }

}

当我在我的Newkey中传递PHONE时,我无法根据PHONE生成值

我不想在put函数中使用Newkey来生成一个keyname,并且基于那个KEYNAME,我不想获得值。

google-app-engine go google-cloud-datastore datastore
1个回答
1
投票

datastore.Get()只能用于通过其密钥从数据存储区获取实体,因此其密钥必须已知/存在。

这显然不是你想要做的。您正在尝试按非关键属性获取实体。为此,您需要运行查询。

数据存储区查询由datastore.Query类型表示。您需要创建一个查询并在其上设置过滤器。在您的情况下,您希望按用户名和/或电话属性进行过滤。

这就是它的样子。获取通过电话过滤的患者实体:

q :=  datastore.NewQuery("Patient").Filter("phone =", patient.Phone)

var patients []*Patient
keys, err := q.GetAll(ctx, &patients)
if err != nil {
    // Handle error
    return
}

// patients contains patients with the given phone number

获取通过电话号码和用户名过滤的患者的示例:

q :=  datastore.NewQuery("Patient").
    Filter("phone =", patient.Phone).
    Filter("username =", patient.UserName)

var patients []*Patient
keys, err := q.GetAll(ctx, &patients)
if err != nil {
    // Handle error
    return
}

// patients contains patients with the given phone number and username
© www.soinside.com 2019 - 2024. All rights reserved.