Mogondb 不支持事務(wù)。所有有事務(wù)要求的需求慎用,比如銀行的轉(zhuǎn)賬操作慎用,轉(zhuǎn)1個億美金,因為網(wǎng)絡(luò),電力的故障導(dǎo)致交易沒有完成,不能回滾,交易無法撤回。所有慎用!!
Mogondb 的應(yīng)用場景:
比如一篇CSDN博客,博客內(nèi)容,博客作者,發(fā)布時間,評論,閱讀量等信息可以將這些信息存儲到一個類似JSON數(shù)據(jù)中。如果用mysql需要將不同的信息分別存儲于不同的表中,使用的時候,查詢多表或者使用JOIN查詢數(shù)據(jù),導(dǎo)致查詢過慢。而使用MongoDB,將數(shù)據(jù)存儲在一起,需要數(shù)據(jù)時,一次就能查詢到數(shù)據(jù)。更新數(shù)據(jù)或者添加數(shù)據(jù)可以在原有的數(shù)據(jù)集上直接更新或者添加,很方便。
MongoDB易于管理,更新數(shù)據(jù),可以不用像傳統(tǒng)的關(guān)系型數(shù)據(jù)使用JOIN來進行查詢,提高性能。
Mogodb擴展起來很容易,可以在多臺服務(wù)器進行部署。而且對于大數(shù)據(jù),對于csdn博客的系統(tǒng)來講,每一天,每一個月,每一年都有大量的博客被寫出來,數(shù)據(jù)量的增長每年都是很大的,mongoDB可以在不停機的情況下進行彈性擴展,
意思是增加上幾臺存儲的服務(wù)器,形成分布式存儲。
MongoDB很適合于這種需求場景的,不知道csdn怎么實現(xiàn)的 ?
MongoDB 還能高效存儲二進制大對象,比如照片,音樂,視頻的存儲,龐大的數(shù)據(jù)還能加索引和實時聚合
mongodb將數(shù)據(jù)存儲在靈活的類似json的文檔中,字段結(jié)構(gòu)可能因文檔而異,數(shù)據(jù)結(jié)構(gòu)可隨時改變
Json模型可以映射到應(yīng)用程序代碼中的對象,這樣就很方便的進行使用,有orm的感覺。
在golang中就可以直接與結(jié)構(gòu)體關(guān)聯(lián)起來。
類似json的文檔數(shù)據(jù)結(jié)構(gòu)叫做BSON,比json最突出的好處是BSON可遍歷。
MongoDB支持二維空間索引,使用空間索引,mongoDB支持一種特殊查詢,如某地圖網(wǎng)站上可以查找離你最近的咖啡廳,銀行等信息。這個使用mongoDB的空間索引結(jié)合特殊的查詢方法很容易實現(xiàn)。
滴滴、膜拜、OFO等基于位置進行查詢的場景都可以使用MongoDB的位置索引。
golang 連接mongodb
golang 沒有官方mongodb驅(qū)動,但是有社區(qū)的驅(qū)動: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("未查詢到數(shù)據(jù)庫名字:",err)
}
fmt.Println(names)
}
運行結(jié)果:
[local mytest]
其他url的拼接規(guī)則:
mongodb://[username:password@]host1[:port1][,host2[:port2],…[,hostN[:portN]]][/[database][?options]]
mongodb:// 這是固定的格式,必須要指定。
username:password@ 可選項,如果設(shè)置,在連接數(shù)據(jù)庫服務(wù)器之后,驅(qū)動都會嘗試登陸這個數(shù)據(jù)庫
host1 必須的指定至少一個host, host1 是這個URI唯一要填寫的。它指定了要連接服務(wù)器的地址。如果要連接復(fù)制集,請指定多個主機地址。
portX 可選的指定端口,如果不填,默認為27017
/database 如果指定username:password@,連接并驗證登陸指定數(shù)據(jù)庫。若不指定,默認打開 test 數(shù)據(jù)庫。
?options 是連接選項。如果不使用/database,則前面需要加上/。所有連接選項都是鍵值對name=value,鍵值對之間通過或;(分號)隔開
參考菜鳥教程或者官方文檔都可以:
http://edu.jb51.net/mongodb/mongodb-connections.html
https://docs.mongodb.com/manual/reference/connection-string/index.html
附加一:
windows 工具 連接mongodb的方式,如果用代碼連接mongodb,發(fā)生錯誤,可以用工具檢查服務(wù)是否能正常被連接。
(一).安裝windows mongodb,參考網(wǎng)址:https://www.jb51.net/article/85605.htm
(二).使用命令行的進入mongodb 安裝目錄中bin目錄中,執(zhí)行
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
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:- Golang Mongodb模糊查詢的使用示例
- mongodb官方的golang驅(qū)動基礎(chǔ)使用教程分享
- Golang對MongoDB數(shù)據(jù)庫的操作簡單封裝教程
- golang操作mongodb的方法
- 詳解Golang使用MongoDB通用操作