【发布时间】:2020-03-12 04:34:39
【问题描述】:
我对 Ignite 还很陌生,正在尝试一下。我的用例是我有一个需要缓存/持久化的模型。它不是传统的 pojo 模型,而且我想保持存储和模型解耦。所以我不能在传统意义上使用它来注释 pojo 中的适当键/索引。并且需要能够对缓存的数据执行查询。
到目前为止,根据我所阅读的内容和我的用例,我看到的唯一选择是:
走完整的 SQL 路线,即使用 Batch Exec 通过 jdbc 创建 TABLE、INSERT、REMOVE、SELECT。
将其存储为 BinaryObject,即
IgniteCache<BinaryObject, BinaryObject>
但是有了这个,我不确定我是否可以获得查询支持。因为它会被存储为 blob/byte[]。
所以我正在寻找的是,还有其他我可能错过的选择吗? 对于 #1,有没有办法使用 jdbc/SQL 和锁定,因为我使用的是 atomicity=transactional。
对于#2,有没有办法可以添加查询支持。我看了https://github.com/dmagda/ignite_world_demo/blob/master/src/main/java/demo/keyvalue/KeyValueBinaryDataProcessing.java 但不包括查询。
更新,供可能遇到此问题的人使用。
尝试过二进制方法,它可以工作。参考链接确实使用了 pojo(不完全是我想要的)。但进一步看,重点是为 QueryEntity 设置一个 valueType,它不必是类名,只是在 put 期间创建对象期间将 value 映射回引用,在查询期间也是如此。
queryEntity.setValueType("employee");
//this can be now referenced while creating an object
ignite.binary().builder("employee");
// similarly used while querying
SqlFieldsQuery sqlQuery = new SqlFieldsQuery("select * from employee");
【问题讨论】:
标签: java ignite distributed-caching