【发布时间】:2016-01-02 04:22:06
【问题描述】:
我尝试使用 Cassandra 来持久化非常简单的 POJO,但使用类层次结构(许多子类,一个超类)。我正在使用 Java 和 Datastax 驱动程序(以及对象映射器)。
我的问题是对象映射器似乎无法识别超类中注释的字段。
我实现的结构是:
@Table(keyspace = "...", name = "...")
public class Subclass extends Superclass {
public double x;
public double y;
public double z;
....
}
public class Superclass {
@PartitionKey(0)
@Column(name = "user_id")
public long userId;
@PartitionKey(1)
@Column(name = "device_id")
public long deviceId;
}
然后我尝试保存子类对象:
public static void main(String[] args) {
Subclass data = new Subclass();
data.deviceId = 123;
data.userId = 1212;
data.x = 0;
data.y = 1;
data.z = 2;
Cluster cluster;
Session session;
...
Mapper<Subclass> mapper = new MappingManager(session).mapper(Subclass.class);
mapper.save(data);
}
这会抛出:
com.datastax.driver.core.exceptions.InvalidQueryException: Missing mandatory PRIMARY KEY part user_id
有没有办法让它在这样的结构中运行?一种解决方案是在子类中重新声明 userId / deviceID 字段,但这会非常难看(很多重复代码)。任何想法如何为这样的案例归档良好的结构或最佳实践?
【问题讨论】:
标签: java inheritance cassandra datastax datastax-java-driver