自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

碼農(nóng)寶典:您對MongoDB知多少?

譯文
數(shù)據(jù)庫 其他數(shù)據(jù)庫 MongoDB
MongoDB是一種領(lǐng)先的NoSQL解決方案,兌現(xiàn)了靈活模式數(shù)據(jù)存儲系統(tǒng)的承諾,為開發(fā)人員提供了一種更快速、更輕松、更自然的方式來構(gòu)建應(yīng)用程序。

[[410595]]

【51CTO.com快譯】NoSQL數(shù)據(jù)存儲讓數(shù)據(jù)管理方式更加靈活,徹底改變了軟件開發(fā)的狀況。MongoDB是知名的NoSQL解決方案之一,這是一種面向文檔的數(shù)據(jù)存儲系統(tǒng)。本文探討MongoDB是什么以及它如何滿足您的應(yīng)用需求。

MongoDB:文檔數(shù)據(jù)存儲系統(tǒng)

關(guān)系數(shù)據(jù)庫將信息存儲在嚴(yán)格監(jiān)管的表和列中。MongoDB是一種文檔存儲系統(tǒng),將信息存儲在集合和文檔中。這里的主要區(qū)別在于集合和文檔是非結(jié)構(gòu)化的,有時稱為無模式。這意味著MongoDB實(shí)例(集合和文檔)的結(jié)構(gòu)不是預(yù)定義的,可靈活適應(yīng)放入其中的任何數(shù)據(jù)。

文檔是一個鍵值集,其行為與JavaScript等代碼中的對象非常相似:它的結(jié)構(gòu)根據(jù)放入其中的數(shù)據(jù)而變化。這使得針對MongoDB等數(shù)據(jù)存儲系統(tǒng)進(jìn)行編程比針對關(guān)系數(shù)據(jù)存儲系統(tǒng)進(jìn)行編程來得更容易、更靈活。簡而言之,應(yīng)用程序代碼和文檔數(shù)據(jù)存儲系統(tǒng)之間的交互感覺更自然。

圖1直觀地顯示了MongoDB數(shù)據(jù)庫、集合和文檔的結(jié)構(gòu)。

圖1. MongoDB文檔存儲系統(tǒng)

這種類型的數(shù)據(jù)建模繼承的靈活性意味著可以在更加按需使用的基礎(chǔ)上處理數(shù)據(jù),從而實(shí)現(xiàn)此處所述的性能優(yōu)勢。

想具體了解這種差異,不妨比較以下兩種實(shí)現(xiàn)相同任務(wù)(創(chuàng)建記錄,然后從應(yīng)用程序添加字段)的方法,先用關(guān)系數(shù)據(jù)庫,之后用MongoDB。

關(guān)系數(shù)據(jù)庫中的步驟:

  1. create a database
  2. CREATE DATABASE menagerie; 
  3. create a table in the database:  
  4. USE menagerie; CREATE TABLE pet (name VARCHAR(20)); 
  5. connect to the database in app and issue insert:  
  6. INSERT INTO pet (nameVALUES ('Friar Tuck'); 
  7. add a column:  
  8. ALTER TABLE pet ADD type VARCHAR(20)); 
  9. update existing record:  
  10. UPDATE pet SET type = 'cat' WHERE name = 'Friar Tuck' 

現(xiàn)在用MongoDB執(zhí)行同樣的過程:

  1. connect to the database in app and issue insert:  
  2. use menagerie; db.pet.insertOne({name:"friar tuck"}); 
  3. # issue update:  
  4. db.pet.updateOne({ name:'friar tuck' }, { $set:{ type: 'cat' } } ); 

從前面您可以了解使用MongoDB的開發(fā)體驗(yàn)有多流暢。

這種靈活性當(dāng)然將避免模式臃腫的負(fù)擔(dān)加在了開發(fā)人員的身上。駕馭大型應(yīng)用程序的文檔結(jié)構(gòu)至關(guān)重要。

MongoDB中的ID字段

關(guān)系型數(shù)據(jù)庫中有主鍵這個概念,這通常是一個合成ID列(也就是說,與業(yè)務(wù)數(shù)據(jù)無關(guān)的生成值)。在MongoDB中,每個文檔都有一個用途相似的_id字段。如果開發(fā)人員在創(chuàng)建文檔時沒有提供 ID,MongoDB引擎將自動生成一個ID(作為 UUID)。

與主鍵一樣,_id 字段自動索引,而且必須是唯一的。

MongoDB中的索引

MongoDB中的索引其行為類似關(guān)系數(shù)據(jù)庫中的索引:它創(chuàng)建有關(guān)文檔字段的額外數(shù)據(jù),以加快依賴該字段的查詢。MongoDB使用 B 樹索引。

可以使用如下語法創(chuàng)建索引:

  1. db.pet.createIndex( { name: 1 } ) 

參數(shù)中的整數(shù)表示索引是升序(1) 還是降序(-1)。

MongoDB中嵌套文檔

MongoDB面向文檔結(jié)構(gòu)的一個強(qiáng)大方面是文檔可以嵌套。比如說,您可以創(chuàng)建嵌套文檔,而不是創(chuàng)建另一個表來存儲寵物文檔的地址信息,結(jié)構(gòu)如代碼片段1所示。

代碼片段1. 嵌套文檔示例

  1.   "_id""5cf0029caff5056591b0ce7d"
  2.   "name""Friar Tuck"
  3.   "address": { 
  4.     "street""Feline Lane"
  5.     "city""Big Sur"
  6.     "state""CA"
  7.     "zip""93920" 
  8.   }, 
  9.   "type""cat" 

MongoDB中的非規(guī)范化

MongoDB等文檔存儲系統(tǒng)對連接的支持有限,也沒有外來鍵的概念。兩者都是數(shù)據(jù)結(jié)構(gòu)動態(tài)特性的結(jié)果。MongoDB中的數(shù)據(jù)建模傾向于非規(guī)范化,即復(fù)制文檔中的數(shù)據(jù),而不是將數(shù)據(jù)嚴(yán)格保存在表孤島中。這提高了查找速度,不過以增加數(shù)據(jù)一致性維護(hù)為代價。

非規(guī)范化不是必需的,在使用面向文檔的數(shù)據(jù)庫時更多地是一種傾向。這是由于處理復(fù)雜嵌套記錄的能力得到了提高,而不是SQL傾向于將數(shù)據(jù)規(guī)范化到特定的單值列中。

MongoDB查詢語言

MongoDB中的查詢語言面向JSON,就像文檔結(jié)構(gòu)一樣。這有助于一種非常強(qiáng)大的表達(dá)式語法,甚至可以處理復(fù)雜的嵌套文檔。

比如說,您可以通過執(zhí)行db.pet.find({ "type" : "cat" })來查詢收錄所有貓咪的理論數(shù)據(jù)庫,或使用db.pet.find({ "type" : "cat" , "address.state": "CA" })來查詢加利福尼亞州的所有貓咪。請注意,查詢語言遍歷嵌套的地址文檔。

MongoDB更新語法

MongoDB的alter語法也使用類似JSON的格式,其中$set關(guān)鍵字表明將更改哪個字段、更改為什么值。set對象通過點(diǎn)表示法支持嵌套文檔,如代表片段2所示,可以在其中更改名為“Friar Tuck”的那只貓的郵政編碼。

代碼片段2. 更新嵌套文檔

  1. db.people.update
  2.   { 
  3.     "type""cat"
  4.     "name""Friar Tuck" 
  5.   }, 
  6.   { 
  7.      $set: { 
  8.        "address.zip""86004" 
  9.      } 
  10.   } 

可以從代碼片段2中看到,更新語法與SQL對應(yīng)語法一樣強(qiáng)大,實(shí)際上更強(qiáng)大。

MongoDB云和部署選項

MongoDB為可擴(kuò)展性和分布式部署而設(shè)計。它完全能夠處理大規(guī)模工作負(fù)載。

MongoDB公司在MongoDB Atlas中提供了多云數(shù)據(jù)庫集群解決方案。MongoDB Atlas就像一個托管數(shù)據(jù)庫,可以橫跨不同的云平臺,包括監(jiān)控和容錯等企業(yè)功能。

不難看出MongoDB的重要性,因此AWS的Amazon DocumentDB產(chǎn)品將MongoDB兼容性作為主要賣點(diǎn)。微軟的Azure Cosmos DB遵循類似的模式,支持MongoDB API。

MongoDB中的高可用性

MongoDB支持副本集以實(shí)現(xiàn)高可用性。核心思想是將數(shù)據(jù)一次寫入主實(shí)例,然后復(fù)制到二級存儲以便讀取。在此處(https://docs.mongodb.com/manual/replication/)可了解有關(guān)MongoDB中復(fù)制的更多信息。

結(jié)論是,MongoDB是一種領(lǐng)先的 NoSQL 解決方案,兌現(xiàn)了靈活模式數(shù)據(jù)存儲系統(tǒng)的承諾??墒褂妹嫦驇缀醺鞣N編程語言的高級驅(qū)動程序,您也可以利用眾多部署選項。

原文標(biāo)題:What is MongoDB? A quick guide for developers,作者:Matthew Tyson

【51CTO譯稿,合作站點(diǎn)轉(zhuǎn)載請注明原文譯者和出處為51CTO.com】

 

責(zé)任編輯:華軒 來源: 51CTO
相關(guān)推薦

2020-05-22 07:00:00

合成完整備份備份數(shù)據(jù)

2022-01-19 17:19:14

區(qū)塊鏈攻擊加密算法

2020-05-08 07:00:00

Linux色碼文件類型

2024-08-06 10:07:15

2012-02-13 22:50:59

集群高可用

2022-11-30 14:57:39

產(chǎn)業(yè)互聯(lián)網(wǎng)

2010-08-16 09:15:57

2013-12-23 14:00:31

Windows 8.2Windows 8.1

2021-12-04 11:17:32

Javascript繼承編程

2025-04-14 08:50:00

Google ADK人工智能AI

2017-07-14 10:51:37

性能優(yōu)化SQL性能分析

2013-11-14 13:58:06

硅谷碼農(nóng)

2009-05-13 17:31:06

DBAOracleIT

2018-08-31 10:53:25

MySQL存儲引擎

2020-09-08 10:56:55

Java多線程存儲器

2021-07-22 07:20:24

JS 遍歷方法前端

2012-09-10 16:38:40

Windows Ser

2017-04-01 09:13:48

編程語言框架

2010-09-29 09:28:04

DHCP工作原理

2018-12-12 15:01:22

開源存儲 軟件
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號