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

NoSQL內戰(zhàn):MongoDB與CouchDB查詢方式對比

原創(chuàng)
數(shù)據(jù)庫 MongoDB
作為目前最時髦的兩種NoSQL數(shù)據(jù)庫,MongoDB與CouchDB在查詢方式上有些許不同。本文將為您揭示這場NoSQL內戰(zhàn)的技術細節(jié)。

【51CTO經(jīng)典譯文】MongoDB和CouchDB都是面向文檔的數(shù)據(jù)庫,它們都使用JSON文檔格式,它倆通常都被看作是NoSQL數(shù)據(jù)庫,并且現(xiàn)在都很時髦,有很多的共同點,但談到查詢時,兩者的差別就很明顯了,CouchDB需要預定義視圖(本質上是JavaScript MapReduce函數(shù)),而MongoDB支持動態(tài)查詢(基本上和傳統(tǒng)關系數(shù)據(jù)庫上的即席查詢類似),更重要的是,談到查詢時,CouchDB的API是RESTful,而MongoDB的API更原生化,這意味著在代碼中發(fā)出一個查詢就要使用一個驅動。

例如,使用CouchDB時,為了插入一些數(shù)據(jù),可以使用一些外部工具,如Groovy的RESTClient:

  1. import static groovyx.net.http.ContentType.JSON  
  2. import groovyx.net.http.RESTClient  
  3.    
  4. def client = new RESTClient("http://localhost:5498/")  
  5. response = client.put(path: "parking_tickets/1234334325",  
  6.   contentType: JSON,  
  7.   requestContentType:  JSON,  
  8.   body: [officer: "Robert Grey",  
  9.          location: "199 Castle Dr",  
  10.          vehicle_plate: "New York 77777",  
  11.          offense: "Parked in no parking zone",  
  12.          date"2010/07/31"]) 

注意,在這種情況下,我必須為停車票指定一個編號(1234334325),順便提一下,也可以要求CouchDB使用UUID,如向/_uuids路徑發(fā)出一個HTTP GET請求。

51CTO編輯向您推薦:強勢的芒果:走進MongoDB

例如,如果我想找出由Officer Grey開出的所有票,我必須定義一個視圖,視圖是執(zhí)行JavaScript MapReduce函數(shù)的簡單URL,因此我可以快速實現(xiàn)一個函數(shù)來提取officer屬性等于Robert Grey的所有文檔。

  1. function(doc) {  
  2.   if(doc.officer == "Robert Grey"){  
  3.     emit(null, doc);  
  4.   }  

我必須給這個視圖取一個名字,當我向這個視圖發(fā)出HTTP GET請求時,至少可以得到一個文檔。

  1. response = client.get(path: "parking_tickets/_view/by_name/officer_grey",  
  2.         contentType: JSON, requestContentType: JSON)  
  3.    
  4. assert response.data.total_rows == 1  
  5. response.data.rows.each{  
  6.    assert it.value.officer == "Robert Grey" 

總的來說,使用CouchDB時,我不能很快地發(fā)出一個即席RESTful調用查詢信息,必須先定義一個查詢(也叫視圖),然后將其暴露出來。相反,使用MongoDB時,它和大多數(shù)關系數(shù)據(jù)庫沒多大區(qū)別,你可以在運行時查詢你想要看到的任何信息。

例如,下面是我使用MongoDB的原生Java驅動實現(xiàn)的停車票實例:

  1. DBCollection coll = db.getCollection("parking_tickets");  
  2. BasicDBObject doc = new BasicDBObject();  
  3.    
  4. doc.put("officer""Robert Grey");  
  5. doc.put("location""199 Castle Dr");  
  6. doc.put("vehicle_plate""New York 77777");  
  7. //...  
  8. coll.insert(doc); 

假設以后我要查詢Robert Smith發(fā)出的停車票,只需要簡單修改一下officer屬性值就可以了,如:

  1. BasicDBObject query = new BasicDBObject();  
  2. query.put("officer""Robert Smith");  
  3. DBCursor cur = coll.find(query);  
  4.  while (cur.hasNext()) {  
  5.    System.out.println(cur.next());  
  6.  } 

雖然MongoDB和CouchDB有很多相似之處,但在查詢方面的確有著本質的不同,CouchDB需要使用MapReduce,而MongoDB更多的是面向動態(tài)的查詢,當然MongoDB也是支持MapReduce的。

原文標題:MongoDB and CouchDB: vastly different queries

延伸閱讀

您如果想了解更多關于數(shù)據(jù)庫查詢方面的資料,51CTO向您推薦《構建高效MySQL查詢》與《數(shù)據(jù)庫之索引與查詢專題

【編輯推薦】

  1. MongoDB CEO談NoSQL的大數(shù)據(jù)量處理能力
  2. 拋棄關系數(shù)據(jù)庫 PHP程序員應了解MongoDB的五件事
  3. MongoDB,無模式文檔型數(shù)據(jù)庫簡介
  4. 關系數(shù)據(jù)庫的末日是否已經(jīng)來臨
  5. 扔掉沉沒成本 嘗試關系數(shù)據(jù)庫替代品OODBMS  
責任編輯:彭凡 來源: 51CTO
相關推薦

2011-03-21 15:08:56

MongoDBCouchDB

2011-08-01 08:56:06

CouchDBSQLiteNoSQL

2017-11-14 18:54:43

MySQLMongoDBNoSQL

2010-08-13 16:40:27

CouchDBAndroid SDKAndroid

2010-09-15 14:47:47

CouchDBNoSQL

2011-08-02 16:08:52

NoSQLMongoDBCassandra

2011-04-01 10:18:22

NoSQLCouchDB

2010-03-30 10:07:37

NoSQL數(shù)據(jù)庫

2023-03-27 16:25:56

SQLNoSQL

2011-05-13 09:46:20

MySQLNoSQL

2019-07-08 10:36:34

數(shù)據(jù)庫WebNoSQL

2013-04-07 09:57:45

CouchbaseMySQLNoSQL

2011-03-04 09:32:31

NoSQL就業(yè)形勢Cassandra

2014-07-31 09:13:54

R語言MongoDB

2014-09-16 10:24:49

PostgreSQLNoSQL

2010-01-04 13:44:41

SQL

2009-12-31 10:49:53

寬帶接入方式

2011-03-11 08:58:26

Apache Couc

2011-04-01 09:29:52

MySQLMongoDB

2011-09-21 11:21:00

NoSQL
點贊
收藏

51CTO技術棧公眾號