首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >[requestPayload]的对象映射尝试将字段[requestPayload]解析为对象,但找到了具体的值

[requestPayload]的对象映射尝试将字段[requestPayload]解析为对象,但找到了具体的值
EN

Stack Overflow用户
提问于 2019-04-20 14:05:12
回答 1查看 426关注 0票数 0

我将JSON字符串作为对象存储在elasticsearch中,但是在下面得到异常,其中requestPayload是我们的JSON字符串体: requestPayload的对象映射试图将字段requestPayload解析为对象,但找到了一个具体的值

方法如下:

代码语言:javascript
复制
@Override
public PushBookingNotification save(PushBookingNotification pushBookingNotification) {
    log.debug("Request to save PushBookingNotification : {}", pushBookingNotification);
    PushBookingNotification result = pushBookingNotificationRepository.save(pushBookingNotification);
    pushBookingNotificationSearchRepository.save(result);
    return result;
}

如下=====所示的====实体

公共类PushBookingNotification实现了可序列化的{

代码语言:javascript
复制
private static final long serialVersionUID = 1L;

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;

@NotNull
@Column(name = "ota_hotel_id", nullable = false)
private Long otaHotelId;

@Column(name = "hotel_name")
private String hotelName;

@NotNull
@Column(name = "reference_no", nullable = false)
private String referenceNo;

@NotNull
@Type(type = "jsonb")
@Column(name = "request_payload", columnDefinition = "jsonb", nullable = false)
@Field(type = FieldType.Object)
private String requestPayload;

// Getter和setter方法

=====错误-记录=======

代码语言:javascript
复制
 ERROR 10409 --- [ XNIO-2 task-11] c.atithih.cms.aop.logging.LoggingAspect  : Exception in com.atithih.cms.service.impl.PushBookingNotificationServiceImpl.save() with cause = 'NULL' and exception = 'object mapping for [requestPayload] tried to parse field [requestPayload] as object, but found a concrete value'

org.elasticsearch.index.mapper.MapperParsingException: object mapping for [requestPayload] tried to parse field [requestPayload] as object, but found a concrete value
    at org.elasticsearch.index.mapper.DocumentParser.parseObjectOrNested(DocumentParser.java:350)
    at org.elasticsearch.index.mapper.DocumentParser.parseObjectOrField(DocumentParser.java:465)
    at org.elasticsearch.index.mapper.DocumentParser.parseValue(DocumentParser.java:591)
    at org.elasticsearch.index.mapper.DocumentParser.innerParseObject(DocumentParser.java:396)
    at org.elasticsearch.index.mapper.DocumentParser.parseObjectOrNested(DocumentParser.java:373)
    at org.elasticsearch.index.mapper.DocumentParser.internalParseDocument(DocumentParser.java:93)
    at org.elasticsearch.index.mapper.DocumentParser.parseDocument(DocumentParser.java:66)
    at org.elasticsearch.index.mapper.DocumentMapper.parse(DocumentMapper.java:277)
    at org.elasticsearch.index.shard.IndexShard.prepareIndex(IndexShard.java:529)
    at org.elasticsearch.index.shard.IndexShard.prepareIndexOnPrimary(IndexShard.java:506)
    at org.elasticsearch.action.bulk.TransportShardBulkAction.prepareIndexOperationOnPrimary(TransportShardBulkAction.java:450)
    at org.elasticsearch.action.bulk.TransportShardBulkAction.executeIndexRequestOnPrimary(TransportShardBulkAction.java:458)
    at org.elasticsearch.action.bulk.TransportShardBulkAction.executeBulkItemRequest(TransportShardBulkAction.java:143)
    at org.elasticsearch.action.bulk.TransportShardBulkAction.shardOperationOnPrimary(TransportShardBulkAction.java:113)
    at org.elasticsearch.action.bulk.TransportShardBulkAction.shardOperationOnPrimary(TransportShardBulkAction.java:69)
    at org.elasticsearch.action.support.replication.TransportReplicationAction$PrimaryShardReference.perform(TransportReplicationAction.java:939)
    at org.elasticsearch.action.support.replication.TransportReplicationAction$PrimaryShardReference.perform(TransportReplicationAction.java:908)
    at org.elasticsearch.action.support.replication.ReplicationOperation.execute(ReplicationOperation.java:113)
    at org.elasticsearch.action.support.replication.TransportReplicationAction$AsyncPrimaryAction.onResponse(TransportReplicationAction.java:322)
    at org.elasticsearch.action.support.replication.TransportReplicationAction$AsyncPrimaryAction.onResponse(TransportReplicationAction.java:264)
    at org.elasticsearch.action.support.replication.TransportReplicationAction$1.onResponse(TransportReplicationAction.java:888)
    at org.elasticsearch.action.support.replication.TransportReplicationAction$1.onResponse(TransportReplicationAction.java:885)
    at org.elasticsearch.index.shard.IndexShardOperationsLock.acquire(IndexShardOperationsLock.java:147)
    at org.elasticsearch.index.shard.IndexShard.acquirePrimaryOperationLock(IndexShard.java:1657)
    at org.elasticsearch.action.support.replication.TransportReplicationAction.acquirePrimaryShardReference(TransportReplicationAction.java:897)
    at org.elasticsearch.action.support.replication.TransportReplicationAction.access$400(TransportReplicationAction.java:93)
    at org.elasticsearch.action.support.replication.TransportReplicationAction$AsyncPrimaryAction.doRun(TransportReplicationAction.java:281)
    at org.elasticsearch.common.util.concurrent.AbstractRunnable.run(AbstractRunnable.java:37)
    at org.elasticsearch.action.support.replication.TransportReplicationAction$PrimaryOperationTransportHandler.messageReceived(TransportReplicationAction.java:260)
    at org.elasticsearch.action.support.replication.TransportReplicationAction$PrimaryOperationTransportHandler.messageReceived(TransportReplicationAction.java:252)
    at org.elasticsearch.transport.RequestHandlerRegistry.processMessageReceived(RequestHandlerRegistry.java:69)
    at org.elasticsearch.transport.TransportService$7.doRun(TransportService.java:644)
    at org.elasticsearch.common.util.concurrent.ThreadContext$ContextPreservingAbstractRunnable.doRun(ThreadContext.java:638)
    at org.elasticsearch.common.util.concurrent.AbstractRunnable.run(AbstractRunnable.java:37)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
    at java.lang.Thread.run(Thread.java:748)
EN

回答 1

Stack Overflow用户

发布于 2019-04-20 16:06:30

为什么在字段requestPayload上有注释@ field (type = FieldType.Object)。也许试着去掉它,它可能会起作用。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55770766

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档