婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Go 在 MongoDB 中常用查詢與修改的操作

Go 在 MongoDB 中常用查詢與修改的操作

熱門標(biāo)簽:涿州代理外呼系統(tǒng) 評價高的400電話辦理 excel地圖標(biāo)注分布數(shù)據(jù) 電話機(jī)器人軟件免費(fèi) 外呼系統(tǒng)用什么卡 壽光微信地圖標(biāo)注 百度地圖標(biāo)注后傳給手機(jī) 阿克蘇地圖標(biāo)注 外呼系統(tǒng)顯本地手機(jī)號

以下所有例子中結(jié)構(gòu)定義如下:

type User struct {
    Id_ bson.ObjectId `bson:"_id"`
    Name string `bson:"name"`
    Age int `bson:"age"`
    JoinedAt time.Time `bson:"joined_at"`
    Interests []string `bson:"interests"`
    Num []int `bson:"num"`
}

1、查詢

通過func (c *Collection) Find(query interface{}) *Query來進(jìn)行查詢,返回的Query struct可以有附加各種條件來進(jìn)行過濾。

通過Query.All()可以獲得所有結(jié)果,通過Query.One()可以獲得一個結(jié)果,注意如果沒有數(shù)據(jù)或者數(shù)量超過一個,One()會報錯。

條件用bson.M{key: value},注意key必須用MongoDB中的字段名,而不是struct的字段名。

1.1、查詢所有

var users []User
c.Find(nil).All(users)

上面代碼可以把所有Users都查出來:

1.2、根據(jù)ObjectId查詢

id := "5204af979955496907000001"
objectId := bson.ObjectIdHex(id)
user := new(User)
c.Find(bson.M{"_id": objectId}).One(user)

更簡單的方式是直接用FindId()方法:

c.FindId(objectId).One(user)

注意這里沒有處理err。當(dāng)找不到的時候用One()方法會出錯。

1.3、單條件查詢

=($eq)
c.Find(bson.M{"name": "Jimmy Kuu"}).All(users)
!=($ne)
c.Find(bson.M{"name": bson.M{"$ne": "Jimmy Kuu"}}).All(users)
>($gt)
c.Find(bson.M{"age": bson.M{"$gt": 32}}).All(users)
($lt)
c.Find(bson.M{"age": bson.M{"$lt": 32}}).All(users)
>=($gte)
c.Find(bson.M{"age": bson.M{"$gte": 33}}).All(users)
=($lte)
c.Find(bson.M{"age": bson.M{"$lte": 31}}).All(users)
in($in)
c.Find(bson.M{"name": bson.M{"$in": []string{"Jimmy Kuu", "Tracy Yu"}}}).All(users)

1.4、多條件查詢

and($and)
c.Find(bson.M{"name": "Jimmy Kuu", "age": 33}).All(users)
or($or)
c.Find(bson.M{"$or": []bson.M{bson.M{"name": "Jimmy Kuu"}, bson.M{"age": 31}}}).All(users)

2、修改

通過func (*Collection) Update來進(jìn)行修改操作。

func (c *Collection) Update(selector interface{}, change interface{}) error

注意修改單個或多個字段需要通過$set操作符號,否則集合會被替換。

2.1、($set)

//修改字段的值
c.Update(
    bson.M{"_id": bson.ObjectIdHex("5204af979955496907000001")},
    bson.M{"$set": bson.M{ "name": "Jimmy Gu", "age": 34 }}
)

2.2、inc($inc)

//字段增加值
c.Update(
    bson.M{"_id": bson.ObjectIdHex("5204af979955496907000001")},
    bson.M{"$inc": bson.M{ "age": -1 }}
)
//字段Num數(shù)組第三個數(shù)增加值
c.Update(
    bson.M{"_id": bson.ObjectIdHex("5204af979955496907000001")},
    bson.M{"$inc": bson.M{ "Num." + strconv.Itoa(2): 1 }})

2.3、push($push)

//從數(shù)組中增加一個元素
c.Update(
    bson.M{"_id": bson.ObjectIdHex("5204af979955496907000001")},
    bson.M{"$push": bson.M{ "interests": "Golang" }}
)

2.4、pull($pull)

//從數(shù)組中刪除一個元素
c.Update(
    bson.M{"_id": bson.ObjectIdHex("5204af979955496907000001")},
    bson.M{"$pull": bson.M{ "interests": "Golang" }}
)

2.5、刪除

c.Remove(bson.M{"name": "Jimmy Kuu"})

補(bǔ)充:golang mongodb查找find demo

使用gopkg.in/mgo.v2庫操作,插入操作主要使用mongodb中Collection對象的Find方法,函數(shù)原型:

func (c *Collection) Find(query interface{}) *Query

查找的時候Find的參數(shù)都會用bson.M類型

type M map[string]interface{}

例如:bson.M{"name": "Tom"}相當(dāng)直接mongodb的查詢條件{"name": "Tom"}

統(tǒng)一封裝下getDB方法

package main
 
import (
     "fmt"
 
     "gopkg.in/mgo.v2"
     "gopkg.in/mgo.v2/bson"
)
 
// get mongodb db
func getDB() *mgo.Database {
     session, err := mgo.Dial( "172.16.27.134:10001" )
     if err != nil {
         panic(err)
     }
 
     session.SetMode(mgo.Monotonic, true)
     db := session.DB( "test" )
     return db
}

查找單條記錄

func findOne() {
     db := getDB()
 
     c := db.C( "user" )
 
     // 用struct接收,一般情況下都會這樣處理
     type User struct {
         Name string  "bson:`name`"
         Age  int     "bson:`age`"
     }
     user := User{}
     err := c.Find(bson.M{ "name" :  "Tom" }).One(user)
     if err != nil {
         panic(err)
     }
     fmt.Println(user)
     // output: {Tom 20}
 
     // 用bson.M結(jié)構(gòu)接收,當(dāng)你不了解返回的數(shù)據(jù)結(jié)構(gòu)格式時,可以用這個先查看,然后再定義struct格式
     // 在處理mongodb組合查詢時,經(jīng)常這么干
     result := bson.M{}
     err = c.Find(nil).One(result)
     if err != nil {
         panic(err)
     }
     fmt.Println(result)
     // output: map[_id:ObjectIdHex("56fdce98189df8759fd61e5b") name:Tom age:20]
 
}

查找多條記錄

func findMuit() {
     db := getDB()
 
     c := db.C( "user" )
 
     // 使用All方法,一次性消耗較多內(nèi)存,如果數(shù)據(jù)較多,可以考慮使用迭代器
     type User struct {
         Id   bson.ObjectId `bson: "_id,omitempty" `
         Name string         "bson:`name`"
         Age  int            "bson:`age`"
     }
     var users []User
     err := c.Find(nil).All(users)
     if err != nil {
         panic(err)
     }
     fmt.Println(users)
     // output: [{ObjectIdHex("56fdce98189df8759fd61e5b") Tom 20}...]
 
     // 使用迭代器獲取數(shù)據(jù)可以避免一次占用較大內(nèi)存
     var user User
     iter := c.Find(nil).Iter()
     for iter.Next(user) {
         fmt.Println(user)
     }
     // output:
     // {ObjectIdHex("56fdce98189df8759fd61e5b") Tom 20}
     // {ObjectIdHex("56fdce98189df8759fd61e5c") Tom 20}
     // ...
}

查找指定字段

主要使用Select函數(shù):

func (q *Query) Select(selector interface{}) *Query
func findField() {
     db := getDB()
 
     c := db.C( "user" )
 
     // 只讀取name字段
     type User struct {
         Name string  "bson:`name`"
     }
     var users []User
     err := c.Find(bson.M{}).Select(bson.M{ "name" :  1 }).All(users)
     if err != nil {
         panic(err)
     }
     fmt.Println(users)
     // output: [{Tom} {Tom} {Anny}...]
 
     // 只排除_id字段
     type User2 struct {
         Name string  "bson:`name`"
         Age  int     "bson:`age`"
     }
     var users2 []User2
     err = c.Find(bson.M{}).Select(bson.M{ "_id" :  0 }).All(users2)
     if err != nil {
         panic(err)
     }
     fmt.Println(users2)
     // output: [{Tom 20} {Tom 20} {Anny 28}...]
 
}

查詢嵌套格式數(shù)據(jù)

func findNesting() {
     db := getDB()
 
     c := db.C( "user" )
 
     // 使用嵌套的struct接收數(shù)據(jù)
     type User struct {
         Name string  "bson:`name`"
         Age  int     "bson:`age`"
         Toys []struct {
             Name string  "bson:`name`"
         }
     }
     var users User
     // 只查詢toys字段存在的
     err := c.Find(bson.M{ "toys" : bson.M{ "$exists" : true}}).One(users)
     if err != nil {
         panic(err)
     }
     fmt.Println(users)
     // output: {Tom 20 [{dog}]}
}

查找數(shù)據(jù)總數(shù)

func count() {
     db := getDB()
 
     c := db.C( "user" )
 
     // 查找表總數(shù)
     count, err := c.Count()
     if err != nil {
         panic(err)
     }
     fmt.Println(count)
     // output: 8
 
     // 結(jié)合find條件查找
     count, err = c.Find(bson.M{ "name" :  "Tom" }).Count()
     if err != nil {
         panic(err)
     }
     fmt.Println(count)
     // output: 6
 
}

對數(shù)據(jù)進(jìn)行排序

使用Sort函數(shù)

func (q *Query) Sort(fields ...string) *Query
func findSort() {
     db := getDB() 
     c := db.C( "user" ) 
     type User struct {
         Id   bson.ObjectId `bson: "_id,omitempty" `
         Name string         "bson:`name`"
         Age  int            "bson:`age`"
     }
     var users []User
     // 按照age字段降序排列,如果升序去掉橫線"-"就可以了
     err := c.Find(nil).Sort( "-age" ).All(users)
     if err != nil {
         panic(err)
     }
     fmt.Println(users)
     // output:
     // [{ObjectIdHex("56fdce98189df8759fd61e5d") Anny 28} ...]
     // ...
}

分頁查詢

使用Skip函數(shù)和Limit函數(shù)

func (q *Query) Skip(n int) *Query
func (q *Query) Limit(n int) *Query
func findPage() {
     db := getDB() 
     c := db.C( "user" ) 
     type User struct {
         Id   bson.ObjectId `bson: "_id,omitempty" `
         Name string         "bson:`name`"
         Age  int            "bson:`age`"
     }
     var users []User
     // 表示從偏移位置為2的地方開始取兩條記錄
     err := c.Find(nil).Sort( "-age" ).Skip( 2 ).Limit( 2 ).All(users)
     if err != nil {
         panic(err)
     }
     fmt.Println(users)
     // output:
     // [{ObjectIdHex("56fdce98189df8759fd61e5d") Anny 20} ...]
     // ...
}

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • Golang Mongodb模糊查詢的使用示例
  • 詳解Golang使用MongoDB通用操作
  • Golang對MongoDB數(shù)據(jù)庫的操作簡單封裝教程

標(biāo)簽:梅河口 重慶 汕頭 雞西 銅川 欽州 蘭州 吐魯番

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Go 在 MongoDB 中常用查詢與修改的操作》,本文關(guān)鍵詞  在,MongoDB,中,常用,查詢,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Go 在 MongoDB 中常用查詢與修改的操作》相關(guān)的同類信息!
  • 本頁收集關(guān)于Go 在 MongoDB 中常用查詢與修改的操作的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    在线视频综合导航| 国产精品沙发午睡系列990531| 精品国内片67194| 亚洲国产综合91精品麻豆 | av亚洲精华国产精华精| 久久综合九色综合欧美就去吻| 麻豆高清免费国产一区| 成人短视频下载| 日本女人一区二区三区| 国产欧美日韩卡一| 欧美电影免费观看高清完整版在线 | 亚洲女厕所小便bbb| 国产福利一区二区三区视频| 91美女在线视频| 色婷婷亚洲精品| 视频一区二区国产| 国产欧美日韩视频在线观看| 欧美xxxxx牲另类人与| 夜夜揉揉日日人人青青一国产精品| 欧美做爰猛烈大尺度电影无法无天| 久久综合色综合88| 蜜桃av噜噜一区| 欧美日韩午夜在线视频| 亚洲图片欧美色图| 欧美日韩成人综合在线一区二区| 一区二区在线观看不卡| 91麻豆免费视频| av一区二区三区在线| 91小视频免费观看| 成人成人成人在线视频| 国产在线播放一区二区三区| 天天综合色天天综合色h| 欧美日韩中文精品| 99久久免费精品高清特色大片| 国产成人免费xxxxxxxx| 欧美日韩一区二区三区四区五区| 欧美日韩国产小视频| 亚洲成人动漫在线免费观看| 国产精品99久久不卡二区| 国产亚洲一区二区三区| 欧美bbbbb| 国产视频一区在线播放| 久久激情五月婷婷| 国产精品美女久久久久高潮| 一本大道久久a久久综合婷婷| 一区二区理论电影在线观看| 欧美顶级少妇做爰| 国产精品资源站在线| 中文子幕无线码一区tr| 轻轻草成人在线| 欧美一级二级三级蜜桃| 久久奇米777| 舔着乳尖日韩一区| 欧美精品久久久久久久久老牛影院| av毛片久久久久**hd| 日韩视频一区在线观看| 成人性生交大片免费看中文网站| 亚洲精品视频观看| 欧美大片一区二区| 91在线国内视频| 黄色小说综合网站| 亚洲视频综合在线| 日韩一级片在线播放| 丰满少妇久久久久久久| 亚洲一线二线三线视频| 久久精品无码一区二区三区| 色婷婷精品大视频在线蜜桃视频| 日韩有码一区二区三区| 中文字幕一区二区三区av| 日韩精品综合一本久道在线视频| 99久久99久久久精品齐齐| 亚洲第一综合色| 国产精品国产馆在线真实露脸 | 亚洲国产成人91porn| 欧美三级中文字| 成人中文字幕电影| 日韩精品91亚洲二区在线观看| 欧美电视剧在线观看完整版| 欧美综合天天夜夜久久| 国产v综合v亚洲欧| 丝袜国产日韩另类美女| 亚洲精品日韩综合观看成人91| www激情久久| 7777精品伊人久久久大香线蕉最新版| 国产精品亚洲专一区二区三区| 亚洲已满18点击进入久久| 国产精品理伦片| 精品免费一区二区三区| 91精品欧美福利在线观看| 一本一道综合狠狠老| 99re免费视频精品全部| 国产成人精品在线看| 美女视频黄 久久| 青青草伊人久久| 午夜欧美在线一二页| 亚洲在线观看免费| 一级做a爱片久久| 国产精品免费aⅴ片在线观看| 久久青草欧美一区二区三区| 久久综合色天天久久综合图片| 日韩欧美在线1卡| 91精品国产色综合久久ai换脸| 欧美日韩视频在线一区二区| 91性感美女视频| 日本道精品一区二区三区| 色久优优欧美色久优优| 色哟哟一区二区在线观看| 99精品在线观看视频| 不卡高清视频专区| 色呦呦日韩精品| 欧美日韩国产综合视频在线观看| 欧美性高清videossexo| 欧美三级日韩三级国产三级| 欧美日本视频在线| 日韩免费观看高清完整版在线观看| 精品国产一区久久| 国产亚洲综合在线| 国产精品久久精品日日| 亚洲乱码国产乱码精品精98午夜| 亚洲综合免费观看高清完整版 | 亚洲欧洲成人自拍| 日韩美女啊v在线免费观看| 亚洲精品久久久久久国产精华液| 亚洲一区二区三区国产| 亚洲成av人**亚洲成av**| 日本不卡1234视频| 国产成人午夜精品5599| 91女人视频在线观看| 欧美色欧美亚洲另类二区| 日韩三级在线观看| 欧美激情一区二区在线| 亚洲一级片在线观看| 麻豆视频观看网址久久| 国产99久久久国产精品免费看| 色一情一伦一子一伦一区| 欧美一区二区三区免费在线看| 2024国产精品| 亚洲精品久久久蜜桃| 久久精品国产亚洲高清剧情介绍 | 亚洲国产成人91porn| 蜜臀av性久久久久蜜臀aⅴ流畅| 国产精品88av| 欧美色区777第一页| 精品久久久久99| 国产精品国产三级国产a| 性感美女久久精品| 成人听书哪个软件好| 在线电影国产精品| 国产精品久久一级| 日本欧美大码aⅴ在线播放| 懂色av一区二区三区蜜臀| 欧美日韩一级视频| 中文成人综合网| 久久国产三级精品| 91麻豆国产自产在线观看| 欧美成人一区二区三区片免费 | 日本欧美大码aⅴ在线播放| 国产aⅴ综合色| 3atv在线一区二区三区| 国产精品家庭影院| 精品综合免费视频观看| 日本大香伊一区二区三区| 中文在线免费一区三区高中清不卡| 亚洲gay无套男同| 成人av在线看| 精品国产乱码久久久久久老虎| 亚洲精品水蜜桃| 国产69精品久久99不卡| 日韩精品一区二区三区老鸭窝| 亚洲国产日韩a在线播放性色| 国产成人在线观看免费网站| 欧美一级欧美三级在线观看| 亚洲综合视频网| 91一区二区在线| 国产欧美一区视频| 奇米在线7777在线精品| 欧美亚洲一区二区在线观看| 国产精品高清亚洲| 国产成人久久精品77777最新版本| 欧美一个色资源| 日韩专区中文字幕一区二区| 色婷婷国产精品| 亚洲丝袜自拍清纯另类| 成人av在线一区二区| 国产免费成人在线视频| 九九精品视频在线看| 日韩欧美亚洲另类制服综合在线| 亚洲午夜久久久久久久久久久| 99久久精品国产麻豆演员表| 久久久久国产成人精品亚洲午夜 | 亚洲国产综合视频在线观看| 91麻豆免费看片| 亚洲三级理论片| av综合在线播放| 国产精品久久久久久久久免费相片 | 久久久精品黄色| 国产在线精品一区二区不卡了 | 日韩欧美三级在线| 看片网站欧美日韩| 精品欧美乱码久久久久久|