Я страдаю проблемой полиорфизма 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;
Так что для того, чтобы десериализации filter
(VARCHAR) в MYSQL Я делаю это 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;
}
, но результатом является то, что jackson ObjectMapper не может десериализовать все сообщения.
Так что-то не так? Какой правильный шаг я должен сделать? Полезные ссылки или документы полезны.
lso, при создании e segmentEntity с использованием Controller 'SegmentController', например create (@RequestBody SegmentEntity segmentEntity), десериализация также трудно кодировать. –