我在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
提前致谢
答案 0 :(得分:1)
这两个过滤器并不完全相同。这似乎有效:
map.put("keys", new String [] {"K1","K2"});