Go与MongoDB

go没有类这一律念,对于变量的捆绑都是由键值对形式的结构体(struct)实现的。
这对一样是以键值对形式存储的mongodb以及json都很是友好。因此在go中,并非很依赖创建在mongodb之上的orm,使用比较底层的驱动级的接口便可方便的进行操做。golang

本篇文章将以商品(goods)为例,简单讲解如何使用mgo进行简单的增删改查操做。mongodb

mgo

mgo (pronounced as mango) is a MongoDB driver for the Go language that implements a rich and well tested selection of features under a very simple API following standard Go idioms.

打开终端输入shell

go get gopkg.in/mgo.v2json

在当前pkg下新建goods.go文件, 对mgo提供的接口进行一些封装:数组

func connect(cName string) (*mgo.Session, *mgo.Collection) {
    session, err := mgo.Dial("$mongoHost") //Mongodb's connection
    if err != nil {
        panic(err)
    }
    session.SetMode(mgo.Monotonic, true)
    //return a instantiated collect
    return session, session.DB(mongoDB).C(cName)
}

定义goods实例:session

type Goods struct {
    ID    string 
    Name  string 
    Price string 
    Url   string
}

接下来咱们要存入第一条记录:code

func (a *Goods) save() error {
    s, c := connect("goods")
    defer s.Close()
    a.ID = bson.NewObjectId().Hex()
    return c.Insert(&a)
}

特别注意: 若是在定义时将ID的类型定义为 bson.ObjectID,并指定bson标签为_id,mongodb将不会为它分配新的id。可是这样的结构在与json作交互时不是很方便。orm

在作记录的查询时,须要新建一个同类型的结构体或结构体数组,而后执行Find操做,若是参数为空,则返回所有记录:接口

func (a Goods) all() ([]Goods, error) {
    s, c := connect("goods")
    defer s.Close()
    var group []Goods
    err := c.Find(nil).All(&group)
    return group, err
}
func (a *Goods) get(id string) error {
    s, c := connect("goods")
    defer s.Close()
    return c.Find(bson.M{"id": id}).One(&a)
}

若是你熟悉mongodb的操做,能够看出,这样的操做与直接在shell内操做几乎相同。get

删除:

func (a Goods) delete() error {
    s, c := connect("goods")
    defer s.Close()
    return c.Remove(bson.M{"id": a.ID})
}

更新:

func (a *Goods) update() error {
    s, c := connect("goods")
    defer s.Close()
    c.Update(bson.M{"id": a.ID}, a)
    return a.get(a.ID)
}
相关文章
相关标签/搜索