草庐IT

文档数据库

全部标签

go - 域和数据库之间的映射

我正在创建从数据库获取数据并将它们作为JSON传递到前端的应用程序。我认为为从数据库中获取的数据和传递给REST服务的数据创建单独的结构是个好主意。我是对的还是我的错?在这种情况下,我需要将结构从一层映射到另一层。我现在在数据库层做:func(ds*DataStore)AddUnit(_unitmodels.Unit){unit:=Unit{}unit.Name=_unit.Nameunit.Description=_unit.Descriptiondb.Create(&unit)}func(ds*DataStore)UpdateUnit(idint,_unitmodels.Unit)

go - 如何在csv文件中的空白处将空字符串值添加到数据库中

我的csv文件有这样的用户数据:firstname|lastname|Email|otherfieldsareempty||||||||||||我使用的代码是:packagemainimport("encoding/csv""gopkg.in/mgo.v2""io""log""os")typeMongostruct{//Idint`json:"_id"bson:"_id"`FirstNamestring`json:"first_name,omitempty"bson:"first_name,omitempty"`LastNamestring`json:"last_name,omitem

elasticsearch - 从 Elasticsearch 中同步删除文档

我正在使用olivere/elastic在Go中使用elasticsearch。这是我的代码://(1)deletedocument_,err:=e.client.Delete().Index(index).Type("entity").Id(id).Do(e.ctx)iferr!=nil{fmt.Println(err.Error())}//(2)getalldocumentsresult,err:=e.client.Search().Index(index).From(1).Size(100).Do(e.ctx)iferr!=nil{log.Println(err)}fmt.Pri

go - mgo 是否具有从查询结果中为每个文档的特定 Slice 字段排序的功能?

我不是在谈论如何对result进行排序。我知道!它是result中我想要按特定顺序排序的字段之一。假设我们有一个由mgo查询返回的result:=[]A{}:typeAstruct{IstringII[]B}typeBstruct{XstringXXint}在那个result中,我希望每个result[i].II按B.XX排序我要问的是,我能否通过mgo完成这种排序,或者我必须循环result并对A.II进行排序自己? 最佳答案 有一种方法可以使用聚合引擎来完成。$匹配你想要的文件$project你想要的字段$展开slice$使用i

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 - 如何更新文档中数组中的字段

我有一个具有以下结构的文档。我想在数组files中插入一个新文件,然后将所有其他文件状态设置为“INACTIVE”。插入后,我正在尝试使用以下代码更新数组的其他文件,但它无法匹配。{{"id":"fafsahjaf867rwhrbjw","files":[{"name":"123",status:"ACTIVE"},{"name":"124",status:"ACTIVE"},{"name":"125",status:"ACTIVE"},{"name":"126",status:"ACTIVE"},]},}query=bson.M{"id":productId,"files":bson

go - 如何在 Go 中以惯用的方式将数据库访问权限转换为函数

我在Go中构建了一个后端API,它可以正常工作,但我想将数据库访问层的代码重构为一个函数-惯用地。//Gettheformdataenteredbyclient;FirstName,LastName,phoneNumber,//assignthepersonauniquei.d//checktoseeifthatuserisn'tinthedatabasealready//iftheyaresendanerrormessagewiththea'bad'responsecode//iftheyaren'tindbaddtodbandsendamessagewithsuccessfuncC

postgresql - 如果我们将数据库/sql 行对象重新分配给 new Query() 的结果会怎样?它会自动关闭吗?还是我们应该自己关闭它?

我正在使用Golang处理postgresql,我处于必须执行多个查询的情况。如果我将每个查询的结果存储在同一个变量中,我们称之为“行”,每次将该变量重新分配给新的查询结果,它会自动关闭以前的行吗?还是我应该每次都手动关闭它们?如果我应该手动关闭它们,如果我每次都推迟rows.Close()会发生什么?有那么必要吗? 最佳答案 如何调用Rows.Close()*在您再次分配给rows`之前?不,Rows.Close()不会被重新分配自动调用。如果您执行多个不同查询,请使用不同变量来保存每个查询返回的行。分配后为每个调用deferro

postgresql - 使用 xo 从 postgres 数据库表模式生成 DTO 结构

我只是想知道是否有人使用过xo.我有一个Postgres数据库,里面有一堆表和东西。我似乎无法使用xo从postgres表结构生成DTOstruct。这个内置的xotemplate似乎创建了一个struct,我相信xo默认使用内置模板,但我在运行时得到的都是xo--verbose--suffix'.go'pgsql://myusername:mypass@localhost:myport/mydb?sslmode=disable-ointernal/qo/models-pqo是一堆与我的项目或我的数据库中的模式完全无关的文件。 最佳答案

go - 使用 godoc 启动本地文档服务器时出现问题

godoc不会返回包列表构建版本go1.11.5。去环境:setGOARCH=amd64setGOBIN=setGOCACHE=C:\Users\dell\AppData\Local\go-buildsetGOEXE=.exesetGOFLAGS=setGOHOSTARCH=amd64setGOHOSTOS=windowssetGOOS=windowssetGOPATH=E:\GoworksetGOPROXY=setGORACE=setGOROOT=C:\GosetGOTMPDIR=setGOTOOLDIR=C:\Go\pkg\tool\windows_amd64setGCCGO=gc