В настоящее время POJO пользователя в моем приложении имеет такой идентификатор ObjectId. п>
Код: Выделить всё
@BsonId
private ObjectId id;
Код: Выделить всё
@BsonId
@BsonRepresentation(BsonType.OBJECT_ID)
private String id;
Код: Выделить всё
Failed to decode 'User'. Decoding '_id' errored with: readString can only be called when CurrentBSONType is STRING, not when CurrentBSONType is OBJECT_ID.
Код: Выделить всё
@PostConstruct
public void init() {
MongoClient mongo = mongoClientProvider.getMongoClient();
MongoDatabase db = mongo.getDatabase("ct6049DB");
collection = db.getCollection("users", User.class);
}
// Get a user by their email
public User getUserByEmail(String email) {
return collection.find(eq("email", email)).first();
}
Код: Выделить всё
CodecRegistry myRegistry = fromRegistries(
MongoClientSettings.getDefaultCodecRegistry(),
fromProviders(PojoCodecProvider.builder().automatic(true).build())
);
Я должен указать, что изменение идентификатора в POJO будет ObjectId, а не String (как указано в ответе здесь: readString можно вызывать только тогда, когда CurrentBSONType имеет значение STRING, а не когда CurrentBSONType равно OBJECT_ID) не является вариантом. Другие ответы на связанный вопрос предлагают удалить все документы в моей коллекции, которые имеют ObjectId для идентификатора (тоже не вариант), добавить @BsonId (который у меня уже есть) и добавить @BsonProperty("id") (что не исправьте проблему, и добавление @BsonProperty("_id") тоже не поможет).
Это для проекта, демонстрирующего различия между базами данных SQL и NoSQL, поэтому было бы неплохо для POJO быть независимым от базы данных (строка для идентификатора), сохраняя при этом предпочтительный тип идентификатора MongoDB в базе данных.
Подробнее здесь: https://stackoverflow.com/questions/791 ... sing-bsonr