成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Go 語言在 MongoDB 中常用查詢與修改的操作,你都會了嗎?

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

以下所有例子中結構定義如下:

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來進行查詢,返回的Query struct可以有附加各種條件來進行過濾。

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

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

1.1、查詢所有

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

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

1.2、根據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。當找不到的時候用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來進行修改操作。

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(set)¨G7G2.2、inc(inc)

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

2.3、push($push)

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

2.4、pull(push)¨G9G2.4、pull(pull)

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

2.5、刪除

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

補充:golang mongodb查找find demo

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

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

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

type M map[string]interface{}

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

統一封裝下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結構接收,當你不了解返回的數據結構格式時,可以用這個先查看,然后再定義struct格式
     // 在處理mongodb組合查詢時,經常這么干
     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方法,一次性消耗較多內存,如果數據較多,可以考慮使用迭代器
     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}...]

     // 使用迭代器獲取數據可以避免一次占用較大內存
     var user User
     iter := c.Find(nil).Iter()
     for iter.Next(&user) {
         fmt.Println(user)
     }
     // output:
     // {ObjectIdHex("56fdce98189df8759fd61e5b") Tom 20}
     // {ObjectIdHex("56fdce98189df8759fd61e5c") Tom 20}
     // ...
}

查找指定字段

func (q *Query) Select(selector interface{}) *Query

上面使用Select函數:

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}...]

}

查詢嵌套格式數據

func findNesting() {
     db := getDB()

     c := db.C( "user" )

     // 使用嵌套的struct接收數據
     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}]}
}

查找數據總數

func count() {
     db := getDB()

     c := db.C( "user" )

     // 查找表總數
     count, err := c.Count()
     if err != nil {
         panic(err)
     }
     fmt.Println(count)
     // output: 8

     // 結合find條件查找
     count, err = c.Find(bson.M{ "name" :  "Tom" }).Count()
     if err != nil {
         panic(err)
     }
     fmt.Println(count)
     // output: 6

}

對數據進行排序使用Sort函數

func (q *Query) Sort(fields ...string) *Query

上面就是使用sort函數的方法

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函數和Limit函數

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} ...]
     // ...
}
責任編輯:武曉燕 來源: Go語言圈
相關推薦

2019-05-20 16:30:36

PythonMySQL存儲

2018-04-26 16:35:44

PythonMySQL存儲

2023-06-30 09:45:00

文件讀寫操作Java

2023-11-27 11:42:46

DjangoPython

2024-08-12 11:32:12

Go語言程序

2022-09-21 07:22:39

mongodb版本docker

2023-12-24 22:30:05

LambdaJava函數

2022-01-17 07:50:37

Go代碼規范

2024-01-02 07:43:47

Go語言靜態類型

2022-08-29 08:05:44

Go類型JSON

2021-06-05 06:52:16

Kubernetes

2023-03-14 23:24:27

Mongodb副本集架構

2025-06-20 09:57:42

2023-08-28 07:02:10

2024-03-18 08:06:59

JavaGo開發

2024-10-18 10:35:10

2022-11-11 08:29:24

C語言中文字符代碼

2024-05-09 08:14:09

系統設計語言多語言

2022-09-29 08:32:14

查詢語句OR

2021-12-14 18:20:23

Github技巧前端
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 狠狠操av | 中文字幕av网 | 夜夜爽99久久国产综合精品女不卡 | 一区不卡在线观看 | 中文字幕一区在线观看视频 | 国产精品美女久久久久aⅴ国产馆 | 久久久精品视频一区二区三区 | 欧美www在线 | av网站免费在线观看 | 国产一级片免费视频 | 国产日韩一区 | 密桃av | 久久精品a级毛片 | 日韩精品在线播放 | 成年人在线视频 | 久久福利| 久久久成人一区二区免费影院 | 日本中文字幕在线视频 | 一级女毛片 | 欧美精品一区二区三区四区 在线 | 二区久久| 欧美午夜精品久久久久久浪潮 | 国产黑丝av | 男女免费观看在线爽爽爽视频 | 久久久久久国产免费视网址 | 91网站在线观看视频 | 亚洲第一成人影院 | 亚洲自拍偷拍免费视频 | 日本亚洲精品成人欧美一区 | 日韩欧美综合 | 国产第一亚洲 | 久久精品国产一区二区三区不卡 | 日韩精品一区二区三区视频播放 | 欧美性猛交一区二区三区精品 | 中文字幕国产 | 久久国产成人精品国产成人亚洲 | 久久久91 | 久久成人精品视频 | 先锋资源吧 | 91在线电影 | 午夜激情免费 |