溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

CouchDB與MongoDB在查詢操作上有哪些區(qū)別

發(fā)布時(shí)間:2021-09-29 10:02:22 來(lái)源:億速云 閱讀:193 作者:柒染 欄目:數(shù)據(jù)庫(kù)

本篇文章為大家展示了CouchDB與MongoDB在查詢操作上有哪些區(qū)別,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過(guò)這篇文章的詳細(xì)介紹希望你能有所收獲。

CouchDB與MongoDB一樣是文檔存儲(chǔ),他們?cè)诤芏喾矫娑己芟嗨?。?jiǎn)單的說(shuō),就是MongoDB的查詢是動(dòng)態(tài)查詢,可以在已有數(shù)據(jù)上進(jìn)行任何規(guī)定條件的查詢,當(dāng)然,為了使我們的查詢更快,需要合理的設(shè)計(jì)索引。

CouchDB與MongoDB在查詢操作上有哪些區(qū)別

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

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

importstaticgroovyx.net.http.ContentType.JSON

importgroovyx.net.http.RESTClient

defclient=newRESTClient("http://localhost:5498/")

response=client.put(path:"parking_tickets/1234334325",

contentType:JSON,

requestContentType:JSON,

body:[officer:"RobertGrey",

location:"199CastleDr",

vehicle_plate:"NewYork77777",

offense:"Parkedinnoparkingzone",

date:"2010/07/31"])

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

例如,如果我想找出由OfficerGrey開(kāi)出的所有票,我必須定義一個(gè)視圖,視圖是執(zhí)行JavaScriptMapReduce函數(shù)的簡(jiǎn)單URL,因此我可以快速實(shí)現(xiàn)一個(gè)函數(shù)來(lái)提取officer屬性等于RobertGrey的所有文檔。

function(doc){

if(doc.officer=="RobertGrey"){

emit(null,doc);

}

}

我必須給這個(gè)視圖取一個(gè)名字,當(dāng)我向這個(gè)視圖發(fā)出HTTPGET請(qǐng)求時(shí),至少可以得到一個(gè)文檔。

response=client.get(path:"parking_tickets/_view/by_name/officer_grey",

contentType:JSON,requestContentType:JSON)

assertresponse.data.total_rows==1

response.data.rows.each{

assertit.value.officer=="RobertGrey"

}

CouchDB與MongoDB在查詢操作上有哪些區(qū)別

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

例如,下面是我使用MongoDB的原生Java驅(qū)動(dòng)實(shí)現(xiàn)的停車票實(shí)例:

DBCollectioncoll=db.getCollection("parking_tickets");

BasicDBObjectdoc=newBasicDBObject();

doc.put("officer","RobertGrey");

doc.put("location","199CastleDr");

doc.put("vehicle_plate","NewYork77777");

//...

coll.insert(doc);

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

BasicDBObjectquery=newBasicDBObject();

query.put("officer","RobertSmith");

DBCursorcur=coll.find(query);

while(cur.hasNext()){

System.out.println(cur.next());

}

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

上述內(nèi)容就是CouchDB與MongoDB在查詢操作上有哪些區(qū)別,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI