golang 连接mongoDB的方法示例

2020-01-28 13:38:17丽君

Mogondb 不支持事务。所有有事务要求的需求慎用,比如银行的转账操作慎用,转1个亿美金,因为网络,电力的故障导致交易没有完成,不能回滚,交易无法撤回。所有慎用!!

Mogondb 的应用场景:

比如一篇CSDN博客,博客内容,博客作者,发布时间,评论,阅读量等信息可以将这些信息存储到一个类似JSON数据中。如果用mysql需要将不同的信息分别存储于不同的表中,使用的时候,查询多表或者使用JOIN查询数据,导致查询过慢。而使用MongoDB,将数据存储在一起,需要数据时,一次就能查询到数据。更新数据或者添加数据可以在原有的数据集上直接更新或者添加,很方便。

MongoDB易于管理,更新数据,可以不用像传统的关系型数据使用JOIN来进行查询,提高性能。

Mogodb扩展起来很容易,可以在多台服务器进行部署。而且对于大数据,对于csdn博客的系统来讲,每一天,每一个月,每一年都有大量的博客被写出来,数据量的增长每年都是很大的,mongoDB可以在不停机的情况下进行弹性扩展,

意思是增加上几台存储的服务器,形成分布式存储。

MongoDB很适合于这种需求场景的,不知道csdn怎么实现的 ?

MongoDB 还能高效存储二进制大对象,比如照片,音乐,视频的存储,庞大的数据还能加索引和实时聚合

mongodb将数据存储在灵活的类似json的文档中,字段结构可能因文档而异,数据结构可随时改变

Json模型可以映射到应用程序代码中的对象,这样就很方便的进行使用,有orm的感觉。

在golang中就可以直接与结构体关联起来。

类似json的文档数据结构叫做BSON,比json最突出的好处是BSON可遍历。

MongoDB支持二维空间索引,使用空间索引,mongoDB支持一种特殊查询,如某地图网站上可以查找离你最近的咖啡厅,银行等信息。这个使用mongoDB的空间索引结合特殊的查询方法很容易实现。

滴滴、膜拜、OFO等基于位置进行查询的场景都可以使用MongoDB的位置索引。

golang 连接mongodb

golang 没有官方mongodb驱动,但是有社区的驱动:http://labix.org/mgo

第一步:连接mongodb


package main

import (
  "gopkg.in/mgo.v2"
  "fmt"
)
func main() {
  session, err := mgo.Dial("mongodb://123.207.215.200:27017")
  defer session.Close()
  if err !=nil {
    fmt.Println(err)
    return
  }
  names,err:=session.DatabaseNames();
  if err !=nil {
    fmt.Println("未查询到数据库名字:",err)
  }
  fmt.Println(names)
}

运行结果:

[local mytest]

其他url的拼接规则:


mongodb://[username:password@]host1[:port1][,host2[:port2],…[,hostN[:portN]]][/[database][?options]] 
mongodb:// 这是固定的格式,必须要指定。