从hazelcast IMap的密钥获取密钥值

时间:2017-04-05 10:22:07

标签: spring hazelcast

我使用spring注释将我的对象放到hazelcast贴图中:

@Cacheable(value = "cacheName", key = "{ #someId1,#someId2}")

public String generateValue(Long someId1, Long someId2)

我想根据放在Imap键上的条件使缓存中的对象无效。我发现key是一个大小等于2的ArrayList。这是预期的结果。

 Set set = cache.keySet(); // this returns Set<ArrayList<Long>>

我尝试在键上设置条件:

EntryObject e = new PredicateBuilder().getEntryObject();
Predicate predicateKey = e.key().get("__key#get(0)").equal(someId1).and(e.get("__key#get(1)").equal(someId2));

但是调用这个谓词最终会失败:

Set<Long> idKeysToInvalidate = cache.keySet(predicateKey);

com.hazelcast.query.QueryException: java.lang.IllegalArgumentException: There is no suitable accessor for '__key#get(0)' on class 'class java.util.ArrayList'
at com.hazelcast.query.impl.getters.ReflectionHelper.createGetter(ReflectionHelper.java:176)

有没有人遇到同样的问题?

2 个答案:

答案 0 :(得分:0)

我自己没有这样做,至少在钥匙上,但你可以试试__key#[0]否则请看这里:http://docs.hazelcast.org/docs/3.8/manual/html-single/index.html#querying-in-collections-and-arrays

答案 1 :(得分:0)

我解决了以下问题:

    EntryObject e = new PredicateBuilder().getEntryObject();
    List<Long> input = Arrays.asList(someId1, someId2);
    Predicate predicateKey = e.key().get("hashCode").equal(input.hashCode());
    Set<List> idKeysToInvalidate = cache.keySet(predicateKey);