Я использую Mongo-Java-Driver 2.13
Я сохранил файл в формате PDF (размер 30mb) в GridFS. Я могу легко выполнять операции ввода, удаления и поиска.Как выполнять операции обновления в GridFS (используя Java)?
MongoClient mongo = new MongoClient("localhost", 27017);
DB db = mongo.getDB("testDB");
File pdfFile = new File("/home/dev/abc.pdf");
GridFS gfs = new GridFS(db,"books");
GridFSInputFile inputFile = gfs.createFile(pdfFile);
inputFile.setId("101");
inputFile.put("title", "abc");
inputFile.put("author", "xyz");
inputFile.save();
данные сохранялись в books.files
и books.chunks
коллекций. Теперь я хочу обновление:
- случае 1: Файл PDF
- случае 2: название или автор
Как выполнить эти операции обновления для случая 1 в GridFS?
Я пришел к выводу, что мне нужно поддерживать несколько версий моих файлов и подбирать правильную версию. Может ли кто-нибудь выразить определенную ясность?
Edit:
я могу обновить метаданные (название, автор) легко.
GridFSDBFile outputFile = gfs.findOne(new BasicDBObject("_id", 101));
BasicDBObject updatedMetadata = new BasicDBObject();
updatedMetadata.put("name", "PG");
updatedMetadata.put("age", 22);
outputFile.setMetaData(newMetadata);
outputFile.save();