欢迎来到[自学php网] ①群 AG亚游集团

AG亚游集团 > 网站后台 > MongoDB >

mongodb BSON的基本使用教程

来源:未知 ?? 时间:2019-02-12 13:16?作者:小飞侠

[导读] 查找 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中为...

查找 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"
)
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:/192aff4168aff42aff428: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)*/
 /caff4Update(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"})/删除
}

总结

最新文章

点击排行

自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号@版权所有AG亚游集团

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

河南高院院长胡道才:建议修改审判法院的建设标准 安邦集团引入保险保障基金注资 启动投资者遴选 赵睿快问快答:给自己智商打满分 出门要带脑子 AI视角复盘:小申屡出最强手 党毅飞官子弈败招 神级晃人?街球大神这样评价哈登 得分仅A-? 罗马主帅:带着谦逊态度战巴萨 罗马风格克巴萨 西安环卫出史上最精细考核 1㎡马路尘土不得超5克 外媒:中国成为国际电子竞技领域有力竞争者 印度恢复试射美制M777榴弹炮 曾因使用国产弹药炸膛 女婴胃被撑破心脏一度停跳 只因被喂这种常见食物 美专家建议将近海战斗舰改造为无人系统母舰 给中美贸易算笔账:算利益 谁是中美贸易的既得利益者
去猛龙莱昂纳德有38%开心!这是大数据分析的 曝勇士签下考神前曾有意他!但为啥最终没要 特朗普:欧盟正对美国采取非常严厉的经济政策 政协委员:建议“教唆 贩卖 服用兴奋剂”入刑 中企造成莫桑比克环境恶化?外交部回应 瑞达期货:金银跳空低开振荡 预计短期震荡偏弱 男子到菲律宾当“客服” 谁料被要求装女人干这事 萨法洛娃赞小德和捷克猛将合作 称进展会很顺利 崔康熙:在主场不会输任何对手 上半场踢得不好 新秀30分名宿之子25+12 湖人收官战轻取快船 罗马赛纳达尔完胜加拿大新星 携西里奇晋级八强 中国奥委会等电贺武大靖夺得中国代表团首金
全国人大宪法和法律委员会对监察法草案进行审议 欠缴社保致无法参与摇号 宝马4S店原职工起诉单位 高盛:美国经济陷入怪圈 小心美联储跳级式加息! 中国移动:2018年提高派息率 将从中国铁塔上市受益 特朗普称关税最伟大遭怼:伤害美消费者 并不伟大 巴拿马酒店将“特朗普”除名 特朗普公司已上诉 人大代表:建议儿童动画片因“岁”施教 内容分级 新华时评:美方一味“任性”只会以完败收场 皇马门神:我拥有世界最佳防线 无惧利物浦三叉戟 马云教你创业 加盟什么店最赚钱 养20头牛一年赚多少钱 利润最高的不起眼行业 AG亚游集团