我将elasticsearch与spring-data结合使用,并且在文档索引方面存在问题。索引可以工作,但是应该跳过一些值。但首先我要向你们展示我的设置:
领域对象:
@Document(indexName = "testindex", type = "message")
public class MessageObject {
@Id
private String unid;
private String message;
private String secondMessage;
private String thirdMessage;
...
getters & setters
...
}接口:
public interface MessageObjectRepository extends ElasticsearchRepository<MessageObject, Long> {
}服务:
@Component
public class MessageService {
@Autowired
private MessageObjectRepository repository;
public void addRegistrationObject(MessageObject msg) {
repository.save(msg);
}
}所以..。
如果我想索引一条只有两条消息集的消息。例如“消息”和"thirdMessage“--我把"secondMessage”空.
如果我检查我的索引,结果如下:
"hits": {
"total": 1,
"max_score": 1,
"hits": [
{
"_index": "testindex",
"_type": "message",
"_id": "00113B325ED357B7C1257E2D001D5B4B",
"_score": 1,
"_source": {
"unid": "00113B325ED357B7C1257E2D001D5B4B",
"message": "Hello",
"secondMessage": null,
"thirdMessage": "Third",
....我的问题是,我不希望在我的索引中有一个空值字段。我找不到任何有用的东西.
如果一个字段有一个空值而忽略它,是否可能呢?(不要将其放在索引中),因此我的索引文档将如下所示:
"unid": "00113B325ED357B7C1257E2D001D5B4B",
"message": "Hello",
"thirdMessage": "Third",没有
"secondMessage": null,我不想要一个忽略空值字段的查询。我想要一个没有空值字段的索引。
发布于 2016-01-05 18:28:38
您应该能够在类级别上指定以下@JsonInclude注释
@JsonInclude(value = JsonInclude.Include.NON_NULL)
@Document(indexName = "testindex", type = "message")
public class MessageObject {
...
}https://stackoverflow.com/questions/34615312
复制相似问题