草庐IT

gorm-mongodb

全部标签

go - 使用 Gorm 将值从一列映射到单独表中的另一列

鉴于以下one-to-many关系(一个Receipt有很多LineItem的),我想映射Price来自Receipt的字段表进入Price领域LineItem表(对于LineItem中的每个Product)。收据架构typeProductstruct{IDuint`json:"id"`TotalPricefloat64`json:"total"`LineItems[]LineItem`json:"lineItems"`}LineItem架构typeLineItemstruct{IDuint`json:"id"`ProductIDuint`json:"productID"`Pricef

mongodb - 我怎样才能在 json 中响应时间毫秒为零

在我的mongodb中,我有字段"createdAt":ISODate("2018-10-02T01:17:58.000Z")我有结构有字段CreatedAttime.Time`json:"createdAt"bson:"createdAt"`但是当我通过json响应时,它缺少零毫秒我以为"createdAt":"2018-10-02T01:17:58.000Z"但是收到了"createdAt":"2018-10-02T01:17:58Z" 最佳答案 来自golang.org/pkg/time/#Time.MarshalJSON:T

mongodb - 如何使用mongodb/mongo-go-driver进行高效分页

我在下面的文章中读到,使用_id的自然顺序执行分页效率更高,因为skip总是从集合的开头开始。FastandEfficientPaginationinMongoDB//Page1db.students.find().limit(10)//Page2last_id=...#logictogetlast_iddb.students.find({'_id':{'$gt':last_id}}).limit(10)但我不知道如何使用mongodb/mongo-go-driver执行上述操作。 最佳答案 你可以创建一个新的函数,不要忘记传递ht

json - 使用 to 将大型 XML 文件转换为 JSON 以存储在 MongoDB 中

对于我的一个项目,我必须处理超过2GB的XML文件。我想存储数据mongoDB。我决定尝试使用Go语言。但我很难找出在Go中执行此操作的最佳方法。我见过很多具有固定XML结构的示例,但我得到的数据结构是动态的,因此使用某种预定义的结构对我来说行不通。现在我偶然发现了这个包:https://github.com/basgys/goxml2json这看起来很有前途,但有几件事我没有得到:自述文件中给出的示例使用的是XML字符串,但我在接受文件的代码中没有看到任何内容。举个例子,我有2GB的xml文件,我不能简单地将整个XML文件加载到内存中。这会影响我的服务器。我认为说得好,我只需要将XM

mongodb - 如何使用 golang 验证查询 mongodb 中的时间

在这里,我正在构建一个查询以从数据库中获取预订,我正在对其进行查询,但根据条件,我想构建一个查询并在时间字段上设置一个条件,如果时间不等于小于零则它将不加入查询条件。以下是我正在使用的条件,我想验证时间:-mongoSession:=ConnectDb()defermongoSession.Close()sessionCopy:=mongoSession.Copy()defersessionCopy.Close()getCollection:=sessionCopy.DB(Database).C(Collection)condition:=bson.M{"status":1,"cate

有 OR 查询的 gorm

我一直在生成一个在运行时动态创建的查询。我想创建一个having查询,中间带有OR,例如SELECTnameFROM`user_group`WHERE((group_key='age'ANDgroup_value='20'))OR((group_key='division'ANDgroup_value='accounting'))OR((group_key='age'ANDgroup_value='22'))OR((group_key='division'ANDgroup_value='kitchen'))GROUP_BYnameHAVING((SUM(group_key='age'A

mongodb - 如何使用 mongo-go-driver 从结构转换为文档

我正在尝试使用$push将go结构放入mongo数组中。我为此示例简化的go文档如下所示:typeMainstruct{IDobjectid.ObjectID`bson:"_id"`Projects[]*Project`bson:"proj"`}typeProjectstruct{IDobjectid.ObjectID`bson:"_id"`Namestring`bson:"name"`}我想要做的是$push一个新的Project到Main.Projects数组。我最终做的事情非常痛苦,所以我希望有更好的方法。看这里://Createthenewprojectstruct:newPr

mongodb - 使用 MongoDB 从 Golang 中的子对象数组中获取值

我正在使用安装了最新版本MongoDB的mgo.v2驱动程序。我的文档结构是这样定义的:typegameTemplatestruct{IDbson.ObjectId`bson:"_id"json:"id"`GameCodestring`bson:"gamecode"json:"gamecode"`Players[]player`bson:"players"json:"players"`}typeplayerstruct{PlayerIDbson.ObjectId`bson:"playerid"json:"playerid"`Usernamestring`bson:"username"j

mongodb - mgo - 查询性能似乎一直很慢(500-650 毫秒)

我的数据层大量使用Mongo聚合,平均而言,查询需要500-650毫秒才能返回。我正在使用mgo。下面显示了一个示例查询函数,它代表了我的大部分查询的样子。func(ruserRepo)GetUserByID(idstring)(User,error){info,err:=db.Info()iferr!=nil{log.Fatal(err)}session,err:=mgo.Dial(info.ConnectionString())iferr!=nil{log.Fatal(err)}defersession.Close()varuserUserc:=session.DB(info.Db

database - 在 go http 中的自定义处理程序中传递 *gorm.db 实例的最佳实践

我正在创建一个自定义网络处理程序来处理网络应用程序中的路由。处理程序是typeCustomHandlerstruct{Db*gorm.DB}然后是接收函数:func(hCustomHandler)Index()http.Handler{returnhttp.handlerFunc(whttp.ResponseWriter,r*http.Request){//Somecode//useh.Db.Find(),etc.})我将其传递给我的路由器作为//InpackagecustomHandler:=&CustomHandler{*gormInstance}//I'vealreadygott