登录
首页 >  Golang >  Go问答

为什么未指定祖先时过滤器不起作用?查询不返回结果?

来源:Golang技术栈

时间:2023-03-07 07:59:04 183浏览 收藏

小伙伴们有没有觉得学习Golang很有意思?有意思就对了!今天就给大家带来《为什么未指定祖先时过滤器不起作用?查询不返回结果?》,以下内容将会涉及到golang,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!

问题内容

为什么未指定祖先时过滤器不起作用?不管祖先,它不应该适用于实体类型吗?

我的用例:我用父键设置了几个实体。该键与另一个实体(主实体)对应,以便我可以通过祖先(主实体键)获取子级。

但是问题似乎是我不能再查询实体属性,除非我指定祖先。这是它应该工作的方式吗?下面是一些伪代码。如果问题不清楚,我可以提供工作代码。

type MyStruct{
  Unique int
}

 key1 := datastore.NewKey(c, "table1", "verylongstring", 0, nil)
 kparent :=  datastore.NewKey(c, "table1", "anotherlongstring", 0, key1)
 x := MyStruct{Unique:23}
 if _, err := datastore.Put(c, kparent, &x); err != nil {
        panic(err)
 }

// This works
 _, err := datastore.NewQuery("table1").Ascentor(kparent).Filter("Unique =", v.Unique).GetAll(cx, dst)

// Query with filter without ancestor doesn't work. Returns no results error.
 _, err := datastore.NewQuery("table1").Filter("Unique =", v.Unique).GetAll(cx, dst)

正确答案

简短的回答:

可以使用非祖先查询(您不使用该方法指定祖先) 查询与父对象一起保存的实体。Query.Ancestor()显然,过滤后的属性必须被索引。

把东西放好:

在您的示例中,与您的命名相反的key1是父键,并且kparent是您保存实体的键。

Query.Ancestor()当您使用该方法创建 Ancestor 查询时,祖先过滤器将结果限制为指定实体及其后代:因此您指定父键,结果将是具有此键的实体(0 或 1 实体)以及那些这是父键!

在您的示例中,您会找到结果,因为实体的键正是您指定的键。通常祖先查询的使用方式是指定父键(而不是实体的键本身),在您的示例中是key1.

需要注意的重要一点:祖先查询是强一致的。 这意味着如果您保存一个带有父级的实体并在此之后立即执行祖先查询(当然,祖先过滤器是同一个父级),您 立即在查询结果中看到保存的实体。

非祖先查询只有 最终一致 。这意味着,如果您保存实体并在此之后立即执行非祖先查询,则查询不包括新保存的实体的可能性非常高,这很可能是您的情况。

属性的索引仅取决于属性的值,并且独立于实体的键,因此键是否具有父级无关紧要。为新实体创建属性的索引条目后,按该属性过滤的查询将包括该实体。这可能需要短至几毫秒或“长”至几秒(不太可能)。

请参阅此相关答案:如何过滤 GAE 查询?这也解释了祖先键和查询。

今天关于《为什么未指定祖先时过滤器不起作用?查询不返回结果?》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于golang的内容请关注golang学习网公众号!

声明:本文转载于:Golang技术栈 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>