0

为什么此过滤器不返回任何实体?我搞不定。其他过滤器工作得很好。

我创建了一个属性设置为字符串列表的实体。List 也是一个集合,因此 Datastore 应该接受它(我认为它确实如此 *)。

Key aliceKey = KeyFactory.createKey("User", user.getEmail());
Entity alice = new Entity(aliceKey);
List<String> roles = new ArrayList<String>();
roles.add("admin");
roles.add("user");
alice.setProperty("role", roles);

我将其保存到数据存储区:

DatastoreService datastore = DatastoreServiceFactory.getDatastoreService();
datastore.put(alice);

现在我进行查询:FilterOperator.IN 需要在 FilterPredicate 构造函数的第三个参数中使用 Iterable,即角色列表。

List<String> rolesList = new ArrayList<String>();
rolesList.add("admin");

Filter propertyFilter =  new FilterPredicate("role", FilterOperator.IN, rolesList);
Query q = new Query("User").setFilter(propertyFilter);
List<Entity> c = datastore.prepare(q).asList(FetchOptions.Builder.withDefaults());

if(c.size()==0)
    response.getWriter().println("nothing");
for (int i = 0; i < c.size(); i++) {
    response.getWriter().println(c.get(i).toString());
}

属性中的值是否在此处以正确的格式显示?这是alice.toString()的输出

Alice: <Entity [User("test@example.com")]:
    role = [admin, zone admin]
>
4

1 回答 1

0

将 FilterOperator.IN 替换为 FilterOperator.EQUALS,并将“admin”作为值传递。

FilterOperator.IN 与您尝试做的相反 - 它查看属性值(单个值)是否等于您在过滤器中传递的任何值。在后台,FilterOperator.IN 作为一系列 FilterOperator.EQUALS 查询执行 - 一个针对过滤器列表中的每个值的查询。

于 2016-10-19T00:05:50.427 回答