草庐IT

查询优化

全部标签

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

postgresql - Golang 和 Postgres 的交互——每次查询都从 int64 表中减去 1

我正在学习创建HTTPAPI,我正在创建一个虚拟的API信用系统,因为这是我特别感兴趣的。这是我想出的:(我正在使用PQDriver)if!dummy.creds但是,假设我将SQL表编辑为50个积分,每次查询虚拟API时如何减去1个积分?例如,如果我查询API并且它从SQL表返回成功的虚拟数据(JSON格式),我如何减去一个学分,这样我只有49个学分,然后是48、47、46,等等更新:这是我想出的_,err:=db.Exec("UPDATEdummySETcreds=-1WHEREemail=$1")iferr!=nil{log.Fatal(err)}它没有工作,没有做任何事情。我做

go - 如何使用 go-pg 查询一对多关系

我想查询一个一对多的关系。我有以下结构:typeAppointmentsParticipantsstruct{AppointmentsIDint`sql:",pk"`UserIDint`sql:",pk"`ApprovedboolReviewedAttime.TimeReviewedByintCommentstringCancelledbool}typeAppointmentsstruct{IDint`sql:",pk"`PendingboolStartTimetime.TimeEndTimetime.TimeauditDataInitialAppointmentIDintSessio

go - go sdk中的DynamoDB查询 `--limit 1`?

--limit1的go-sdk等价物是什么?我可以在CLI中执行以下操作:awsdynamodbquery--table-nameTABLE_NAME...--limit1我不确定如何在go-SDK中执行此操作,我尝试了以下操作:varparameter=&dynamodb.QueryInput{TableName:aws.String("TABLE_NAME"),KeyConditions:map[string]*dynamodb.Condition{...},SetLimit:aws.String("1"),}response,err:=Dyna.Db.Query(paramete

mongodb - 如何在使用 go 的 mongodb 查询中使用 $or 和 $lookup?

我想使用$or和$lookup从mongodb文档中获取数据记录。这是我为断言所做的查询:-pipeline1:=[]bson.M{{"$lookup":bson.M{"from":"comment","localField":"_id","foreignField":"blog_id","as":"comments"}},{"$addFields":bson.M{"comments":bson.M{"$size":"$comments"}}},}pipe1:=getCollection.Pipe(pipeline1)在上面的查询中,它将首先计算记录并添加具有特定数据的字段。但是现在我

arrays - 在 golang 中使用写入文件字节优化

我有以下程序,可以在.pem文件中打印出关于每个证书的信息:packagemainimport("crypto/x509""encoding/pem""io/ioutil""log""os""strconv")funcmain(){//fordevpurposessetto256constSignatureLengthint=256certPEMBlock,err:=ioutil.ReadFile("testsign.crt")iferr!=nil{log.Fatal(err)}varblocks[][]bytefor{varcertDERBlock*pem.BlockcertDERB

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 - 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

mongodb - 如何制定正确的mongo查询以获取正确格式的记录

这里我想做一个根据parent绑定(bind)数据的查询。我收到以下对象:{"_id":1,"name":"home","slug":"home","parent":0,"description":"thiswilldirectyouonhomepage","order":1,"taxonomy":"nav_bar"}{"_id":2,"name":"Links","slug":"links","parent":0,"description":"thiswilldirectyouonhomepage","order":2,"taxonomy":"nav_bar"}{"_id":3,"n