mongodb中BSON怎么利用?BSON使用示例详解
发布时间:2022-04-22 11:02:59 所属栏目:系统 来源:互联网
导读:BSON是一个数据格式,主要用于mongodb中,也是mongodb中最基础的数据存储格式,文本就主要给大家介绍mongodb BSON格式的基本使用,感兴趣的朋友就继续往下看吧。 查找 Find m := bson.M{ create_time: bson.M{ $gte: start, $lte: end, }, account: account,
BSON是一个数据格式,主要用于mongodb中,也是mongodb中最基础的数据存储格式,文本就主要给大家介绍mongodb BSON格式的基本使用,感兴趣的朋友就继续往下看吧。 查找 Find m := bson.M{ "create_time": bson.M{ "$gte": start, "$lte": end, }, "account": account, "tag": "tag", } session.DB("db").C("collect").Find(m).Count() 这里查找时间戳内,账号为account,标签为tag的数据并统计个数。 聚合管道在mgo中为Pipe(pipeline interface{}) 这个和bash中使用的管道很像,数据可以被层层处理。一般传入的参数为[]bson.M。这个[]bson.M里如果还有嵌套则还要使用[]bson.M - 比如这里首先匹配标签和账号 - 时间戳在一段时间内 - 然后根据名字分组统计数量 - 最后排序取最前面的三个。 //这个就可以传入Pipe m := []bson.M{ {"$match": bson.M{"tag": "tag", "account": account, "create_time": bson.M{"$gte": start, "$lte": end}}}, {"$group": bson.M{"_id": "$TagName", "count": bson.M{"$sum": 1}}}, {"$sort": bson.M{"count": -1}}, {"$limit": 3}, } //这里就可以取到输出的数据 var values []result session.DB("db").C("collect").Pipe(m).All(&values) 简单介绍 package main import ( "gopkg.in/mgo.v2" "log" "gopkg.in/mgo.v2/bson" Id: bson.NewObjectId(), Name: "JK_WEI", PassWord: "qwer", Age: 5, }, &User{ Id: bson.NewObjectId(), Name: "JK_HE", PassWord: "6666", Age: 7, })*/ (编辑:济南站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |