Java mongo操作spring mongo批量操作执行异常(codeConfigurationException:Can';找不到类的编解码器)
我试图使用SpringMongo操作类在mongodb中执行批量操作 以下是我的POJO课程: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
@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();