Java mongo操作spring mongo批量操作执行异常(codeConfigurationException:Can';找不到类的编解码器)

Java mongo操作spring mongo批量操作执行异常(codeConfigurationException:Can';找不到类的编解码器),java,spring,mongodb,spring-boot,Java,Spring,Mongodb,Spring Boot,我试图使用SpringMongo操作类在mongodb中执行批量操作 以下是我的POJO课程: @Document(collection = "location_settings_mst") public class LocationSettingsEntity { @Id private String id; @Field("userId") private String userId; @Field("location") private Li

我试图使用SpringMongo操作类在mongodb中执行批量操作

以下是我的POJO课程:

@Document(collection = "location_settings_mst")
public class LocationSettingsEntity {
    @Id
    private String id;
    @Field("userId")
    private String userId;
    @Field("location")
    private List<LocationSettingEntity> locationSettings = new LinkedList<>();
    // Getters and Setters
}

public class LocationSettingEntity {
    @Field("name")
    private String name;
    @Field("latitude")
    private double lat;
    @Field("longitude")
    private double lon;
    @Field("geoPoint")
    private String geoPoint;
    // Getters and Setters
}
我试着调试,发现com.mongodb库检查数据类型的编解码器,如果找不到,就会抛出错误。据我所知,spring mongo操作能够处理POJO


我不明白我错过了什么。请帮忙

从技术上讲,您可以编写自定义编解码器。 我这样做了,但它没有工作,然后我跳入Mongo驱动程序代码,似乎有一个错误

看来他们犯了个错误- com.mongodb.DBCollection#DBCollection(java.lang.String、com.mongodb.DB、com.mongodb.operation.OperationExecutor)

在这里,他们从默认的静态编解码器注册表中设置集合编解码器,因此该注册表将永远无法获取人们编写的自定义编解码器。互联网上有很多ppl都被这个问题困扰着

但是,可以通过将更新负载转换为DBObject来解决这个问题,DBObject可以使用com.mongodb.basicdbobobjectbuilder类来完成,而且非常简单。不确定性能是否会像编解码器一样好。我正在考虑编写自己的dbobjectbuilder,它将为我提供性能。因为我认为最基本的是使用json

Update update = new Update();
update.pushAll("location", list.stream().map(BasicDBObjectBuilder.start().add(//key,value pairs).get()).collect(Collectors.toList()).toArray());
bulkOps = bulkOps.updateOne(query, update);
bulkOps.execute();

如果需要更多信息,请告诉我!!塔克斯
org.bson.codecs.configuration.CodecConfigurationException: Can't find a codec for class com.panasonic.persistence.entity.LocationSettingEntity.
    at org.bson.codecs.configuration.CodecCache.getOrThrow(CodecCache.java:46)
    at org.bson.codecs.configuration.ProvidersCodecRegistry.get(ProvidersCodecRegistry.java:63)
    at org.bson.codecs.configuration.ProvidersCodecRegistry.get(ProvidersCodecRegistry.java:37)
    at com.mongodb.DBObjectCodec.writeValue(DBObjectCodec.java:210)
    at com.mongodb.DBObjectCodec.encodeMap(DBObjectCodec.java:220)
    at com.mongodb.DBObjectCodec.writeValue(DBObjectCodec.java:196)
    at com.mongodb.DBObjectCodec.encode(DBObjectCodec.java:128)
    at com.mongodb.DBObjectCodec.encode(DBObjectCodec.java:61)
    at org.bson.codecs.BsonDocumentWrapperCodec.encode(BsonDocumentWrapperCodec.java:63)
    at org.bson.codecs.BsonDocumentWrapperCodec.encode(BsonDocumentWrapperCodec.java:29)
    at com.mongodb.connection.UpdateCommandMessage.writeTheWrites(UpdateCommandMessage.java:84)
    at com.mongodb.connection.UpdateCommandMessage.writeTheWrites(UpdateCommandMessage.java:42)
    at com.mongodb.connection.BaseWriteCommandMessage.encodeMessageBodyWithMetadata(BaseWriteCommandMessage.java:129)
    at com.mongodb.connection.RequestMessage.encodeWithMetadata(RequestMessage.java:160)
    at com.mongodb.connection.WriteCommandProtocol.sendMessage(WriteCommandProtocol.java:212)
    at com.mongodb.connection.WriteCommandProtocol.execute(WriteCommandProtocol.java:101)
    at com.mongodb.connection.UpdateCommandProtocol.execute(UpdateCommandProtocol.java:64)
    at com.mongodb.connection.UpdateCommandProtocol.execute(UpdateCommandProtocol.java:37)
    at com.mongodb.connection.DefaultServer$DefaultServerProtocolExecutor.execute(DefaultServer.java:159)
    at com.mongodb.connection.DefaultServerConnection.executeProtocol(DefaultServerConnection.java:286)
    at com.mongodb.connection.DefaultServerConnection.updateCommand(DefaultServerConnection.java:140)
    at com.mongodb.operation.MixedBulkWriteOperation$Run$3.executeWriteCommandProtocol(MixedBulkWriteOperation.java:480)
    at com.mongodb.operation.MixedBulkWriteOperation$Run$RunExecutor.execute(MixedBulkWriteOperation.java:646)
    at com.mongodb.operation.MixedBulkWriteOperation$Run.execute(MixedBulkWriteOperation.java:399)
    at com.mongodb.operation.MixedBulkWriteOperation$1.call(MixedBulkWriteOperation.java:179)
    at com.mongodb.operation.MixedBulkWriteOperation$1.call(MixedBulkWriteOperation.java:168)
    at com.mongodb.operation.OperationHelper.withConnectionSource(OperationHelper.java:230)
    at com.mongodb.operation.OperationHelper.withConnection(OperationHelper.java:221)
    at com.mongodb.operation.MixedBulkWriteOperation.execute(MixedBulkWriteOperation.java:168)
    at com.mongodb.operation.MixedBulkWriteOperation.execute(MixedBulkWriteOperation.java:74)
    at com.mongodb.Mongo.execute(Mongo.java:781)
    at com.mongodb.Mongo$2.execute(Mongo.java:764)
    at com.mongodb.DBCollection.executeBulkWriteOperation(DBCollection.java:2195)
    at com.mongodb.BulkWriteOperation.execute(BulkWriteOperation.java:136)
    at org.springframework.data.mongodb.core.DefaultBulkOperations.execute(DefaultBulkOperations.java:266)
DBObjectCodec getDefaultDBObjectCodec() {
    return new DBObjectCodec(MongoClient.getDefaultCodecRegistry(),
                             DBObjectCodec.getDefaultBsonTypeClassMap(),
                             getObjectFactory());
}
Update update = new Update();
update.pushAll("location", list.stream().map(BasicDBObjectBuilder.start().add(//key,value pairs).get()).collect(Collectors.toList()).toArray());
bulkOps = bulkOps.updateOne(query, update);
bulkOps.execute();