有效地存储数据存储标签(用于通过标签获取)

时间:2017-12-27 00:48:33

标签: google-cloud-datastore

我经常遇到这样的情况:

type Article struct {
    Title   string
    User    string
    Content []byte
    Tags    []string
}

我希望能够执行这样的查询任务:

var articles []Article
query := datastore.NewQuery("Article")
for _, filter := range filters {
    if filter.User != "" {
        query = query.Filter("User =", filter.User)
    }
    // how to do if for finding tags
}
keys, err := DatastoreClient().GetAll(ctx, query, &articles)
if err != nil {
    return nil, err
}
return articles, nil

我们假设某篇文章包含以下标记[]string{"golang", "ruby", "python", "programming"},并且我想检索包含标记golangprogramming的所有文章,我怎样才能有效地实现这一目标?

1 个答案:

答案 0 :(得分:1)

在数据存储区中搜索使用等号的数组作为包含。

https://cloud.google.com/datastore/docs/concepts/queries#properties_with_array_values_can_behave_in_surprising_ways

这意味着,您需要通过此属性使用两个相同的过滤器进行查询。 关于GQL的示例。

SELECT * FROM Article WHERE Tags = "golang" AND Tags = "prgramming".

如果Tags是一个数组,则equal将表现为contains。那个。所有的伎俩。