以下代码失败,因为电子邮件字段实际上是一个列表,我想知道在应用程序引擎中处理此问题的正确/有效/惯用方式是什么?
type Person struct {
Name string
Company string
Email []EmailAddress
}
type EmailAddress {
Type string // home, office, etc...
Email string
}
var items []Person
q := datastore.NewQuery("Person").Filter("Company =", company).Filter("Email = ", email).Limit(1)
_, err := a.client.GetAll(a.ctx, q, &items)
它失败并显示以下消息,我认为这是由于电子邮件字段是某种“集合”而引起的:
datastore: bad query filter value type: invalid Value type func() string
我是否需要做一些事情,例如拆分电子邮件地址字段,即:
type Person struct {
Name string
Company string
EmailType []string // home, office
EmailAddress []string // bob@work, bob@home
}
答案 0 :(得分:1)
您可能需要将电子邮件引用为实体Structured Property Email
的属性,而不是Person
实体本身的属性。
我看到Go支持加载/保存此类属性(请参见Nested structs on GAE datastore using Go),并以Python文档中指示的相同方式支持查询过滤:
.Filter("Email.Email = ", email)