golang mongodb mysql_golang使用mgo连接MongoDB

github:https://github.com/ZhangzheBJUT/blog/blob/master/mgo.md 现在MongoDB官方还没有推出关于官方支持的golang的driver,推荐使用的是mgo. mgo的详细文档说明:http://godoc.org/labix.org/v2/mgo 下面是我开发中自己写的一个用mgo连接MongoDB数据库的使

github:https://github.com/ZhangzheBJUT/blog/blob/master/mgo.md

现在MongoDB官方还没有推出关于官方支持的golang的driver,推荐使用的是mgo. mgo的详细文档说明:http://godoc.org/labix.org/v2/mgo

下面是我开发中自己写的一个用mgo连接MongoDB数据库的使用实例。

package main

import (

"fmt"

"labix.org/v2/mgo"

"labix.org/v2/mgo/bson"

)

type Person struct {

NAME string

PHONE string

}

type Men struct {

Persons []Person

}

const = (

URL = "192.168.2.175:27017"

)

func main() {

session, err := mgo.Dial(URL) //连接数据库

if err != nil {

panic(err)

}

defer session.Close()

session.SetMode(mgo.Monotonic, true)

db := session.DB("mydb") //数据库名称

collection := db.C("person") //如果该集合已经存在的话,则直接返回

//*****集合中元素数目********

countNum, err := collection.Count()

if err != nil {

panic(err)

}

fmt.Println("Things objects count: ", countNum)

//*******插入元素*******

temp := &Person{

PHONE: "18811577546",

NAME: "zhangzheHero"

}

//一次可以插入多个对象 插入两个Person对象

err = collection.Insert(&Person{"Ale", "+55 53 8116 9639"}, temp)

if err != nil {

panic(err)

}

//*****查询单条数据*******

result := Person{}

err = collection.Find(bson.M{"phone": "456"}).One(&result)

fmt.Println("Phone:", result.NAME, result.PHONE)

//*****查询多条数据*******

var personAll Men //存放结果

iter := collection.Find(nil).Iter()

for iter.Next(&result) {

fmt.Printf("Result: %v\n", result.NAME)

personAll.Persons = append(personAll.Persons, result)

}

//*******更新数据**********

err = collection.Update(bson.M{"name": "ccc"}, bson.M{"$set": bson.M{"name": "ddd"}})

err = collection.Update(bson.M{"name": "ddd"}, bson.M{"$set": bson.M{"phone": "12345678"}})

err = collection.Update(bson.M{"name": "aaa"}, bson.M{"phone": "1245", "name": "bbb"})

//******删除数据************

_, err = collection.RemoveAll(bson.M{"name": "Ale”})

}

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值