【问题标题】:How to perform Update operations in GridFS (using Java)?如何在 GridFS 中执行更新操作(使用 Java)?
【发布时间】:2015-06-13 10:49:36
【问题描述】:

我正在使用 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();

数据保存在books.filesbooks.chunks 集合中。现在我想更新

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

如何在 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();

【问题讨论】:

    标签: java mongodb gridfs mongodb-java


    【解决方案1】:

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

    你可以做的是:

    1. 插入具有新名称的新文件
    2. 发生这种情况后(使用已确认的副本 write-concern),更新对旧文件的所有引用以指向新文件
    3. 确认后,您可以删除旧文件

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

    【讨论】:

      猜你喜欢
      • 2020-10-01
      • 1970-01-01
      • 2020-05-09
      • 1970-01-01
      • 1970-01-01
      • 2019-07-19
      • 2012-04-19
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多