【发布时间】:2015-06-05 23:25:47
【问题描述】:
我使用不同的NoSQL 数据库,根据数据库,我需要将“id”命名为不同的。因此,例如在OrientDB 中,id 被命名为“@rid”
@JsonProperty("@rid")
private String id;
对于 MongoDB,id 被命名为“_id”
@JsonProperty("@_id")
private String id;
我不知道现代数据库开发人员有什么问题,而不仅仅是将 id 字段命名为“id”^^。但现在我有一个问题。如何动态序列化/反序列化 id 字段,在某些情况下为“@rid”,在另一种情况下为“_id”?
编辑:
根据 rmullers 的建议,我尝试使用 mixins。所以我有例如:
public interface IdMixins {
}
public interface MongoIdMixIn extends IdMixins {
@JsonProperty("_id") String getId();
@JsonProperty("_id") void setId(String id);
}
public interface OrientIdMixIn extends IdMixins{
@JsonProperty("@rid") String getId();
@JsonProperty("@rid") void setId(String id);
}
IdMixins 是一个完全空的接口,仅用于更好地控制哪些接口可以传递给映射器。
然后有一个类:
@JsonTypeInfo(use=JsonTypeInfo.Id.CLASS, include=JsonTypeInfo.As.PROPERTY, property="@javaClass")
public abstract class AbstractBean implements Serializable {
private static final long serialVersionUID = -1286900676713424199L;
// @JsonProperty("@rid")
private String id;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
}
但是当我运行这个简单的测试时,输出仍然是“id”:
public class MixinTest {
public static void main(String[] args) throws JsonProcessingException {
Foo f = new Foo();
f.setId("123");
f.setBar("lala");
ObjectMapper mapper = new ObjectMapper();
ObjectMapper m2 = mapper.copy();
m2.addMixInAnnotations(AbstractBean.class, MongoIdMixIn.class);
System.out.println(m2.writeValueAsString(f));
ObjectMapper m3 = mapper.copy();
m3.addMixInAnnotations(AbstractBean.class, OrientIdMixIn.class);
System.out.println(m3.writeValueAsString(f));
}
public static class Foo extends AbstractBean {
private String bar;
public String getBar() {
return bar;
}
public void setBar(String bar) {
this.bar = bar;
}
}
}
输出:
{"@javaClass":"test.MixinTest$Foo","id":"123","bar":"lala","@class":"Foo"} {"@javaClass":"test.MixinTest$Foo","id":"123","bar":"lala","@class":"Foo"}
【问题讨论】: