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中文网,转载请注明出处,感谢您的尊重!

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

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:深蓝海洋 设计师:CSDN官方博客 返回首页
评论

打赏作者

白小烨

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值