mongodb BSON的基本使用教程
发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,查找 Findm := bson.M{ "create_time": bson.M{ "$gte": start, "$lte": end, }, "accoun
千家信息网最后更新 2025年01月20日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 mainimport ( "gopkg.in/mgo.v2" "log" "gopkg.in/mgo.v2/bson")type User struct { Id bson.ObjectId `bson:"_id"` Name string `bson:"name"` PassWord string `bson:"pass_word"` Age int `bson:"age"`}func main() { db, err := mgo.Dial("mongodb://192.168.2.28:27017,192.168.2.28:27018,192.168.2.28:27019/?replicaSet=howie") if err != nil { log.Fatalln(err) } defer db.Close() db.SetMode(mgo.Monotonic, true) c := db.DB("howie").C("person") //插入 /*c.Insert(&User{ Id: bson.NewObjectId(), Name: "JK_CHENG", PassWord: "123132", Age: 2, }, &User{ Id: bson.NewObjectId(), Name: "JK_WEI", PassWord: "qwer", Age: 5, }, &User{ Id: bson.NewObjectId(), Name: "JK_HE", PassWord: "6666", Age: 7, })*/ var users []User c.Find(nil).All(&users) //查询全部数据 log.Println(users) c.FindId(users[0].Id).All(&users) //通过ID查询 log.Println(users) c.Find(bson.M{"name": "JK_WEI"}).All(&users) //单条件查询(=) log.Println(users) c.Find(bson.M{"name": bson.M{"$ne": "JK_WEI"}}).All(&users) //单条件查询(!=) log.Println(users) c.Find(bson.M{"age": bson.M{"$gt": 5}}).All(&users) //单条件查询(>) log.Println(users) c.Find(bson.M{"age": bson.M{"$gte": 5}}).All(&users) //单条件查询(>=) log.Println(users) c.Find(bson.M{"age": bson.M{"$lt": 5}}).All(&users) //单条件查询(<) log.Println(users) c.Find(bson.M{"age": bson.M{"$lte": 5}}).All(&users) //单条件查询(<=) log.Println(users) /*c.Find(bson.M{"name": bson.M{"$in": []string{"JK_WEI", "JK_HE"}}}).All(&users) //单条件查询(in) log.Println(users) c.Find(bson.M{"$or": []bson.M{bson.M{"name": "JK_WEI"}, bson.M{"age": 7}}}).All(&users) //多条件查询(or) log.Println(users) c.Update(bson.M{"_id": users[0].Id}, bson.M{"$set": bson.M{"name": "JK_HOWIE", "age": 61}}) //修改字段的值($set) c.FindId(users[0].Id).All(&users) log.Println(users) c.Find(bson.M{"name": "JK_CHENG", "age": 66}).All(&users) //多条件查询(and) log.Println(users) c.Update(bson.M{"_id": users[0].Id}, bson.M{"$inc": bson.M{"age": -6,}}) //字段增加值($inc) c.FindId(users[0].Id).All(&users) log.Println(users)*/ //c.Update(bson.M{"_id": users[0].Id}, bson.M{"$push": bson.M{"interests": "PHP"}}) //从数组中增加一个元素($push) c.Update(bson.M{"_id": users[0].Id}, bson.M{"$pull": bson.M{"interests": "PHP"}}) //从数组中删除一个元素($pull) c.FindId(users[0].Id).All(&users) log.Println(users) c.Remove(bson.M{"name": "JK_CHENG"})//删除}
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
查询
条件
数据
时间
元素
内容
字段
数组
标签
管道
账号
学习
统计
三个
个数
价值
参数
名字
增加值
就是
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
云计算和网络安全专业
国内网络安全公司 360
当前网络安全工程师的前景
php数据库获取表中数据
苹果自带的浏览器服务器停止了
三珠数码软件开发上海
国内著名网络安全事件
数据库delete恢复
向网络安全专家提问题
安卓软件开发的技术支持
电脑服务器稳压器
零基础如何学网络安全
网络技术课后习题答案
网件a7000网络安全密钥
海外服务器app下载
武汉c语言软件开发公司
钉钉撤回的消息服务器上有保存吗
数据库组织机构
服务器电脑不显示d盘如何修复
数据库中的内容不见了
海康平台服务器组网
电信如何开通数据库
网络安全渗透测试入门
数据库登录卡顿怎么办
执行网络安全法
生存怎么找之前玩过的服务器
人民共和国网络安全法自实施
公安部数据库
域名可以追踪服务器吗
关于网络安全的积极文章