1
我正在遭受Spring-Mybatis多态性问题。下面是详细: 我有一个Entity
:春天Mybatis多态性
public class SegmentEntity {
private int id;
private String name;
private Filter filter;
// getter and setter
}
public class Filter {
private String type;
}
其中滤波器是多态的。 上有过滤某些子类,如:
public class OneFilter extends Filter {
private String field1;
private int field2;
}
public class AnotherFilter extends Filter {
private List<Integer> field3;
private double field4;
}
正如你可以看到,每个子类都有不同的type
不同的架构。
和MySQL表segment
像:
CREATE TABLE `segment` {
`id` int(11) NUL NULL AUTO_INCREMENT,
`name` varchar(32) NOT NULL,
`filter` varchar(1024) NOT NULL,
PRIMARY KEY (`id`)
} ENGINE=InnoDB DEFAULT CHARSET=utf8;
因此,为了在MYSQL反序列化filter
(VARCHAR)我做这个FilterTypeHandler:
public class FilterTypeHandler implements TypeHandler<Filter> {
@Override
public Filter getResult(ResultSet rs, String columnName) throws SQLException {
String json = rs.getString(columnName);
Filter filter = null;
try {
filter = new ObjectMapper().readValue(json, Filter.class);
} catch (IOException e) {}
return filter;
}
}
,为了让杰克逊做多态反序列化,我更换过滤器类:
@JsonIgnoreProperties(ignoreUnknown = true)
@JsonTypeInfo(use = JsonTypeInfo.Id.NAME, property = "type")
@JsonSubTypes({@JsonSubTypes.Type(value = OneFilter.class, name = "someTypeName"),
@JsonSubTypes.Type(value = AnotherFilter.class, name = "anotherTypeName")})
public class Filter {
private String type;
}
但结果是,杰克逊ObjectMapper不能反序列化所有消息。
那么有什么不对吗?我应该做什么正确的步骤? 任何有用的链接或文档都很有帮助。
一个另外,当使用Controller(如SegmentController)创建e segmentEntity(@RequestBody SegmentEntity segmentEntity)时,反序列化也很难编码。 –