我有一个文件要存储在 mongoDB 中。我想要的是避免加载整个文件(大小可能为几 MB),而是我想打开流并将其定向到 mongoDB 以保持写入操作的性能。我不介意将内容存储在 base64 编码的 byte[] 中。
然后我想在读取文件时做同样的事情,即不将整个文件加载到内存中,而是在流中读取它。
我目前正在将 hibernate-ogm 与 Vertx 服务器一起使用,但如果它能有效地解决问题,我愿意切换到不同的 api。
我想实际存储一个包含多个字段和多个附件的文档。
最佳答案
您可以使用 GridFS .特别是当您需要存储较大的文件 (>16MB) 时,这是推荐的方法:
File f = new File("sample.zip");
GridFS gfs = new GridFS(db, "zips");
GridFSInputFile gfsFile = gfs.createFile(f);
gfsFile.setFilename(f.getName());
gfsFile.setId(id);
gfsFile.save();
或者如果你有一个 InputStream in
:
GridFS gfs = new GridFS(db, "zips");
GridFSInputFile gfsFile = gfs.createFile(in);
gfsFile.setFilename("sample.zip");
gfsFile.setId(id);
gfsFile.save();
您可以使用 GridFS.find
方法之一加载文件:
GridFSDBFile gfsFile = gfs.findOne(id);
InputStream in = gfsFile.getInputStream();
关于java - 用Java将流写入mongoDB,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36151868/