Oracle Coherence中的参数化搜索返回空列表

时间:2013-11-08 10:47:21

标签: java oracle-coherence

我在Coherence中使用IN语句和参数化列表进行搜索时出现问题。

这里我正在使用示例数据创建缓存:

NamedCache cache = CacheFactory.getCache("test-cache");
Some s2 = new Some();
s2.setId(2);
s2.setName("name 2");
cache.put("K2", s2);
Some s3 = new Some();
s3.setId(3);
s3.setName("name 3");
cache.put("K3", s3);

这里我试图使用参数化查询获得结果:

Map<String, ? super Object> map = new HashMap();
map.put("keys", Arrays.asList(new String [] {"K1","K2"}));
Filter filter = QueryHelper.createFilter("key() in :keys", map);
List<Some> list = new ArrayList<Some>(cache.entrySet(filter));

的System.out.println(过滤器);打印看似正确的过滤器配置:

  

InFilter(KeyExtractor(extractor = IdentityExtractor),[[K1,K2]])

我期望它返回带有键K2的单个元素的列表,但它返回空列表。

但是,如果我手动将密钥列表打印到查询字符串中,我会得到正确的结果:

Filter filter = QueryHelper.createFilter("key() in ('K1','K2')");

的System.out.println(过滤器);在这种情况下打印基本相同:

  

InFilter(KeyExtractor(extractor = IdentityExtractor),[K1,K2])

Oracle Coherence 3.7.1.0

提前致谢

1 个答案:

答案 0 :(得分:1)

这两个过滤器并不完全相同。这似乎有效:

 map.put("keys", new String [] {"K1","K2"});