dev*_*v ツ 4 java mongodb gridfs mongodb-java
我正在使用Mongo-Java-Driver 2.13我在GridFS 中存储了一个 PDF 文件(大小30mb)。我能够轻松地执行插入、删除和查找操作。
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();
Run Code Online (Sandbox Code Playgroud)
数据在坚持books.files和books.chunks收藏。现在我想更新:
如何在 GridFS 中为案例 1执行这些更新操作?
我开始知道我需要维护我的文件的多个版本并选择正确的版本。有人可以澄清一下吗?
编辑:
我可以轻松更新元数据(标题、作者)。
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();
Run Code Online (Sandbox Code Playgroud)
在 GridFS 中,您不是删除/删除单个文档,而是实际上是一堆文档(文件被分成多个块,每个块都是一个单独的文档)。这意味着根本不可能以原子方式替换文件。
你可以做的是:
GridFS 是一种黑客功能。通常最好使用带有真实文件系统的单独文件服务器来存储文件内容,并且只将元数据存储在 MongoDB 中。