golang 连接mongoDB的方法示例
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驱动,但是有社区的驱动:
第一步:连接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:// 这是固定的格式,必须要指定。
username:password@ 可选项,如果设置,在连接数据库服务器之后,驱动都会尝试登陆这个数据库
host1 必须的指定至少一个host, host1 是这个uri唯一要填写的。它指定了要连接服务器的地址。如果要连接复制集,请指定多个主机地址。
portx 可选的指定端口,如果不填,默认为27017
/database 如果指定username:password@,连接并验证登陆指定数据库。若不指定,默认打开 test 数据库。
?options 是连接选项。如果不使用/database,则前面需要加上/。所有连接选项都是键值对name=value,键值对之间通过&或;(分号)隔开
参考菜鸟教程或者官方文档都可以:
附加一:
windows 工具 连接mongodb的方式,如果用代码连接mongodb,发生错误,可以用工具检查服务是否能正常被连接。
(一).安装windows mongodb,参考网址:
(二).使用命令行的进入mongodb 安装目录中bin目录中,执行
c:\program files\mongodb\server\3.6\bin>mongo 123.207.215.200:27017
需要注意的是 此时的url 没有”mongodb://”
linux的方式类似:
root@vm-192-98-ubuntu:/usr/local/mongodb/bin# ./mongo 127.0.0.1
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。