cassandra - 无法从 cassandra 读取 map

标签 cassandra cql datastax-java-driver

我在我的一张表格中使用 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/

相关文章:

cassandra - Cassandra 中的原子批处理

java - 使用 Datastax CQL 驱动程序插入 Cassandra 时设置 TTL

cassandra - 将批处理RDD中的结果与Apache Spark中的流式RDD合并

node.js - Cassandra - 使用 Nodejs 模块 helenus 引发 getaddrinfo ENOENT 错误

Cassandra 最佳实践 : it is a good idea to add Ha Proxy in front of Cassandra?

file - Neo4j:如何将评论添加到* .cql(密码)文件中?

cassandra - 如何正确选择与索引匹配的分区键

nosql - 跟踪用户关系的最佳数据库是什么?

cassandra - 将 Kubernetes 外部的 Datastax 连接到 Kubernetes 中的 Cassandra 集群

Cassandra:将新节点引导到集群时 Long Par New GC 暂停