Mongo-go-driver GridFS 元数据
来源:stackoverflow
时间:2024-04-03 20:57:37 301浏览 收藏
大家好,我们又见面了啊~本文《Mongo-go-driver GridFS 元数据》的内容中将会涉及到等等。如果你正在学习Golang相关知识,欢迎关注我,以后会给大家带来更多Golang相关文章,希望我们能一起进步!下面就开始本文的正式内容~
我为我工作的公司编写了一个聊天应用程序,并且我与 mgo 驱动程序一起工作了一段时间。 现在我们将 mgo 重构为官方 mongo 驱动程序。 我已经实现了 gridfs 来处理聊天文件,因为它们并不大,而且它简化了工作。 以前的 mgo 驱动程序在保存文件时有一个数据列表,其中一个字段是 contenttype(很好,对吧?)
因此,在重构此任务中包含的大部分服务后,我注意到新的官方 mongo 驱动程序不会执行此操作?
所以我决定尝试手动添加此字段,但后来我发现我不明白该怎么做?
尝试过 options.gridfsupload().setmetadata(metadata)
但我不明白它的逻辑,而且互联网对于在 go 中工作的新 mongo 驱动程序的结果来说确实很小。
任何人都可以给我提示如何将自定义字段添加到文件文档吗? 喜欢内容类型!!
非常感谢。
这是我尝试做的一个例子
// GridFSInsert - func GridFSInsert(fileName string, data []byte, metadata ...bsonx.Elem) (primitive.ObjectID, error) { checkMongoConnection(false) var fileID primitive.ObjectID bucket, bucketErr := gridFs.NewBucket( Mongo.Client.Database(Mongo.DBName), options.GridFSBucket().SetName(gridFSColName), ) if bucketErr != nil { return fileID, bucketErr } uploadStream, uploadStreamErr := bucket.OpenUploadStream( fileName, options.GridFSUpload().SetMetadata(metadata), ) if uploadStreamErr != nil { return fileID, uploadStreamErr } defer uploadStream.Close() fileSize, writeErr := uploadStream.Write(data) if writeErr != nil { return fileID, writeErr } fileID = uploadStream.FileID log.Printf("Write file to DB was succesful, File size: %d", fileSize) return fileID, nil }
很抱歉,如果我错过了一些东西,因为我对 go 的经验并不如我所愿。
感谢您的帮助
解决方案
没有您想要理解的逻辑。之所以在新的官方mongo驱动中找不到太多关于contenttype的信息,是因为contentType has been deprecated in gridfs spec早在驱动编写之前就已经存在了。
我必须承认gridfs documentation没有提到它。事实上官方 mongofiles cli 仍然使用旧格式。
规范说得很清楚:
注意:某些旧版本的 gridfs 实现允许应用程序向根级别的文件集合文档添加任意字段。 gridfs 的新实现不允许这样做,但必须准备好处理可能具有其他字段的现有文件集合文档。
如果您喜欢更详细的信息official reasoning:
为什么 contenttype 被弃用?
文件集合文档中的大多数字段都由驱动程序直接使用,但元数据、contenttype 和别名除外。所有纯粹用于应用程序的信息都应嵌入“元数据”文档中。我们鼓励想要存储 contenttype 以在其应用程序中使用的 gridfs 用户将“contenttype”字段添加到“元数据”文档,而不是使用已弃用的顶级“contenttype”字段。
这有点道理。驱动程序从字面上遵循规范的措辞 - 除了 metadata
之外,无法在任何地方创建 contenttype
属性,但 bucket.find 仍将返回由“旧版本”创建的文件的 contenttype
。
从旧版 gridfs 到新格式的一次性转换可以非常简单:
db.getcollection("fs.files").aggregate([ {$addfields: { "length" : {$tolong: "$length"}, "metadata.contenttype": { $ifnull: [ "$contenttype", "$metadata.contenttype" ] } }}, { $out : "fs.files" } ])
假设您的存储桶是默认的“fs”,并且您不打算上传旧格式的文件。
如果您有足够的可用空间,那么 out
到新的临时集合,验证它,然后重命名并不是一个糟糕的主意。
如果您出于任何原因必须支持旧格式,您仍然可以直接访问 gridfs 集合:
// in your code snippet after fileid = uploadstream.fileid // update the document that represent uploaded file files := db.collection("fs.files") updateresult, err := files.updateone( context.background(), bson.d{{"_id", fileid}}, bson.d{{"$set", bson.d{{"contenttype", contenttype}}}}, )
其中“fs”是您的存储桶名称,contenttype
是您要设置为 contenttype 的字符串值。
请记住,“某些旧版本”使用 int32 作为文件长度。新驱动程序期望它是 int64。 对于单独使用 *.fiiles 集合的类似 find 的操作应该没问题,但可能会导致使用新的官方驱动程序下载此类文件时出现问题。
这里是 setmetadata()
的示例。
opts := options.GridFSUpload() opts.SetMetadata(bsonx.Doc{{Key: "content-type", Value: bsonx.String("application/json")}}) if ustream, err = bucket.OpenUploadStream("test.txt", opts); err != nil { t.Fatal(err) }
这是 full example
今天关于《Mongo-go-driver GridFS 元数据》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
-
502 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
139 收藏
-
204 收藏
-
325 收藏
-
477 收藏
-
486 收藏
-
439 收藏
-
357 收藏
-
352 收藏
-
101 收藏
-
440 收藏
-
212 收藏
-
143 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习