使用go在mangodb中進行CRUD操作

 更新時間:2019-10-08 15:00:58   作者:佚名   我要評論(0)

我在學習go語言之前,在對數據庫進行CRUD的操作基本是用java和sql來對mysql數據庫進行操作,但是到了實習中公司業務都是用的是mangodb,通過一段學習時間后,

我在學習go語言之前,在對數據庫進行CRUD的操作基本是用java和sql來對mysql數據庫進行操作,但是到了實習中公司業務都是用的是mangodb,通過一段學習時間后,我有了一些收獲。

簡述關系型數據庫,非關系型數據庫

關系型數據庫:指采用了關系模型來組織數據的數據庫。
關系模型指的就是二維表格模型,而一個關系型數據庫就是由二維表及其之間的聯系所組成的一個數據組織

非關系型數據庫

非關系型數據庫:指非關系型的,分布式的,且一般不保證遵循 ACID 原則的數據存儲系統。

這是比較規范的說法,具體這兩者談不上誰優誰劣,各自有各自的使用場景。

其實可以粗暴的理解成一個關系型數據庫基本靠使用sql語句來操作,而非關系型數據靠key-value來進行操作

(其實按我的理解非關系型數據庫嚴格上不是一種數據庫,應該是一種數據結構化存儲方法的集合,可以是文檔或者鍵值對等,但是我不知道這么說是否正確)

MangoDB

好了,上面簡述了一下關系型和非關系型數據庫,下面來說一下今天文章的主角。

mangodb

MongoDB 將數據存儲為一個文檔,數據結構由鍵值(key=>value)對組成。MongoDB 文檔類似于 JSON 對象。字段值可以包含其他文檔,數組及文檔數組。

所以mangodb操作也是通過json(bson)格式來操作

 

那么go語言中是如何來操作mangodb

(1)數據庫連接

數據庫連接主要用到了mgo中的Dial()函數,連接形式如mgo.Dial(url1,url2,url3),具體代碼如下:

func ConnecToDB() *mgo.Collection {
 session, err := mgo.Dial("127.0.0.1:27017")
 if err != nil {
  panic(err)
 }
 //defer session.Close()
 session.SetMode(mgo.Monotonic, true)
 c := session.DB("medex").C("student")
 return c
}

(2)插入

func InsertToMogo() {
 c := ConnecToDB()
 stu1 := Student{
  Name: "xiaoming",
  Phone: "18933333333",
  Email: "[email protected]",
  Sex: "man",
 }
 stu2 := Student{
  Name: "zhangdao",
  Phone: "8765432",
  Email: "[email protected]",
  Sex: "woman",
 }
 err := c.Insert(&stu1, &stu2)
 if err != nil {
  log.Fatal(err)
 }
}

(3)查詢

func GetDataViaSex() {
 c := ConnecToDB()
 result := Student{}
 err := c.Find(bson.M{"sex": "woman"}).One(&result)
 if err != nil {
  log.Fatal(err)
 }
 fmt.Println("student", result)
 students := make([]Student, 20)
 err = c.Find(nil).All(&students)
 if err != nil {
  log.Fatal(err)
 }
 fmt.Println(students)

}
func GetDataViaId() {
 id := bson.ObjectIdHex("5a66a96306d2a40a8b884049")
 c := ConnecToDB()
 stu := &Student{}
 err := c.FindId(id).One(stu)
 if err != nil {
  log.Fatal(err)
 }
 fmt.Println(stu)
}

這上面用了兩種查詢方法一種是查詢多個,返回多個對象:many

另一種是查詢單個,返回單個對象:one

(4)更新

func UpdateDBViaId() {
 //id := bson.ObjectIdHex("5a66a96306d2a40a8b884049")
 c := ConnecToDB()
 err := c.Update(bson.M{"email": "[email protected]"}, bson.M{"$set": bson.M{"name": "haha", "phone": "37848"}})
 if err != nil {
  log.Fatal(err)
 }
}

(5)刪除

func RemoveFromMgo() {
 c := ConnecToDB()
 _, err := c.RemoveAll(bson.M{"phone": "13480989765"})
 if err != nil {
  log.Fatal(err)
 }
}

總結

以上所述是小編給大家介紹的使用go在mangodb中進行CRUD操作,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

相關文章

最新評論

黑龙江新11选5开奖结果