如何在GridFS中执行更新操作(使用Java)?

我使用的Mongo-Java-Driver 2.13是在 存储了一个PDF文件( 大小

。我能够轻松地执行插入,删除和查找操作。

    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.filesbooks.chunks。现在我要 :

  • 案例1:pdf文件
  • 情况2:标题或作者

如何在GridFS中对 执行这些更新操作?

我知道我需要维护文件的多个版本并选择正确的版本。有人可以澄清一下吗?

我可以轻松更新元数据(标题,作者)。

    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();

回答:

在GridFS中,您不是要删除/删除单个文档,而是实际上要删除一堆文档(文件分为多个块,每个块都是一个单独的文档)。这意味着根本不可能以原子方式替换文件。

您可以做的是:

  1. 插入一个具有新名称的新文件
  2. 发生这种情况之后(使用已 确认副本的复制 关注),将所有对旧文件的引用更新为指向新文件
  3. 确认后,您可以删除旧文件

GridFS是一种hackish功能。通常最好只使用带有真实文件系统的单独文件服务器来存储文件内容,并且仅将元数据存储在MongoDB中。

以上是 如何在GridFS中执行更新操作(使用Java)? 的全部内容, 来源链接: utcz.com/qa/407633.html

回到顶部