我在我的一张表格中使用 map ,如下所示:
media map<UUID, frozen<map<int, varchar>>>
虽然我能够成功插入/更新此 map ,但无法从中读取。
我正在使用 datastax java 驱动程序 3.0.0
到目前为止我已经尝试过:
Map<UUID, Map> media = row.getMap("media", UUID.class, Map.class);
但是这一行给出了以下异常:
com.datastax.driver.core.exceptions.CodecNotFoundException: Codec not found for requested operation: [map<int, varchar> <-> java.util.Map]
如何读取该字段?
最佳答案
您正在尝试使用GettableByNameData.getMap(String, Class, Class)
方法。相反,要获取像 Map
这样的复杂数据类型,您可以使用 GettableByNameData.getMap(String, TypeToken, TypeToken)
方法。
import com.google.common.reflect.TypeToken;
TypeToken uuidToken = new TypeToken<UUID>() {};
TypeToken mapToken = new TypeToken<Map<Integer, String>>() {};
Map<UUID, Map<Integer, String>> media = row.getMap("media", uuidToken, mapToken);
关于cassandra - 无法从 cassandra 读取 map ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39659492/