美文网首页
2019-05-16

2019-05-16

作者: sujeking | 来源:发表于2019-05-16 13:35 被阅读0次

    连接mongodb

    gopkg.in/mgo.v2

    • 引入包
    import (
        "fmt"
        "gopkg.in/mgo.v2"
        "gopkg.in/mgo.v2/bson"
    )
    
    • 定义一个model

    注意 _id

    type User struct {
        _id   bson.ObjectId `bson:_id`
        Upass string        `bson:upass`
        Type  int           `bson:type`
        Uname string        `bson:uname`
    }
    
    • 连接
    session, err := mgo.Dial("localhost:21117")
        if err != nil {
            fmt.Println("连接失败")
            fmt.Println(err)
        } else {
            fmt.Println("连接成功")
        }
    
    session.SetMode(mgo.Monotonic, true)
    
    • 选择库、表
    db := session.DB("chinese_tea") //选择数据库
    c := db.C("user") //选择表
    
    • 添加

    db.user.insert({"uname":"golang jkeing"})

        //---------------------------------------
        err = c.Insert(&User{Uname:"golang jeking",_id:bson.NewObjectId()}) //_id必须要有才可以
        if err != nil {
            fmt.Println(err)
        } else {
            fmt.Println("插入成功")
        }
    
    
    • 删除

    db.user.deleteOne({"uname":"里斯"})

        err = c.Remove(bson.M{"uname": "kkk"})
        if err != nil {
            fmt.Println(err)
        } else {
            fmt.Println("删除成功")
        }
    
    • 更新

    db.user.update({"uname":"golang jeking"},{$set:{"uname":"golang sujeking"}})

    err = c.Update(
                    bson.M{"uname": "golang jeking"},
                    bson.M{"$set":
                        bson.M{"uname": "golang sujeking"}
                    })
        if err != nil {
            fmt.Println(err)
        } else {
            fmt.Println("更新成功")
        }
    
    • 查询/全部

    db.user.find({})

        var users []User
        c.Find(nil).All(&users)
        fmt.Println(users)
    
    • 查询/过略字段

    db.user.find({},{"_id":0})

    var users []User
    c.Find(nil).Select(bson.M{"_id":0}).All(&users)
    fmt.Println(users)
    

    混合查询的话 得到的结果集就不能了使用对象了model,但是可以定义一个类型来接收,

    type LocalData interface{}
    
    var users []LocalData
    c.Find(nil).All(&users)
    for _,value := range users { //value 是一个map
      fmt.Println(value);
    }
    

    相关文章

      网友评论

          本文标题:2019-05-16

          本文链接:https://www.haomeiwen.com/subject/rxqiaqtx.html