分享
  1. 首页
  2. 文章

Go与MongoDB

myWsq · · 2990 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

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

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

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.

打开终端输入

go get gopkg.in/mgo.v2

在当前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实例:

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

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

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做交互时不是很方便。

在做记录的查询时,需要新建一个同类型的结构体或结构体数组,然后执行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内操作几乎相同。

删除:

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)
}

有疑问加站长微信联系(非本文作者)

本文来自:Segmentfault

感谢作者:myWsq

查看原文:Go与MongoDB

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
2990 次点击
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏