一、Insert操作
Insert操作是MongoDB插入數(shù)據(jù)的基本方法,對(duì)目標(biāo)集合使用Insert操作,會(huì)將該文檔添加到MongoDB并自動(dòng)生成相應(yīng)的ID鍵。文檔結(jié)構(gòu)采用類似JSON的BSON格式。常見(jiàn)的插入操作主要有單條插入和批量插入兩種形式。插入時(shí)只是簡(jiǎn)單地將文檔存入數(shù)據(jù)庫(kù)中,不進(jìn)行額外的驗(yàn)證,也不會(huì)執(zhí)行代碼,所以不存在注入式攻擊的可能。
1、單條插入
2、批量插入
MongoDB對(duì)批量插入的支持是通過(guò)傳遞多個(gè)文檔組成的數(shù)組到數(shù)據(jù)庫(kù)來(lái)實(shí)現(xiàn)的。由于它插入數(shù)據(jù)是通過(guò)發(fā)送TCP請(qǐng)求的,這樣只需發(fā)送單個(gè)TCP請(qǐng)求,且數(shù)據(jù)庫(kù)無(wú)需處理大量的消息頭,減少插入時(shí)間。這種方式的批量插入一次只能將多個(gè)文檔插入到一個(gè)集合中,對(duì)于插入到多個(gè)集合可以循環(huán)調(diào)用Insert操作。
二、Remove操作
remove函數(shù)可以用來(lái)刪除數(shù)據(jù),它能接受一個(gè)文檔作為可選參數(shù),只有符合條件的文檔才會(huì)被刪除。刪除數(shù)據(jù)是永久性的,不能撤銷,也不能恢復(fù),需要謹(jǐn)慎。刪除文檔需要清空整個(gè)集合,不如直接刪除集合快。
三、Update操作
update函數(shù)用于修改數(shù)據(jù)庫(kù)中的數(shù)據(jù),它接收兩個(gè)參數(shù),一個(gè)是查詢文檔,用來(lái)查找要更新的文檔,另一個(gè)是修改器文檔,用來(lái)描述對(duì)找到的文檔做哪些修改。更新操作是原子性的,如果多個(gè)更新同時(shí)發(fā)生,則所有的更新都會(huì)執(zhí)行,但最后的更新是最終贏家。
1、整體更新(文檔替換)
2、局部更新(修改器)
部分更新是通過(guò)原子的更新修改器實(shí)現(xiàn)的,使用修改器時(shí)除了”_id“的值不能改變,其他任何值都能改變。文檔替換是可以改變所有值的。
$inc修改器:將指定屬性的值增加特定的步長(zhǎng),如果鍵不存在則創(chuàng)建它。
$set修改器:用來(lái)指定一個(gè)鍵的值,如果不存在則創(chuàng)建它。
$push:數(shù)組修改器,如果指定的鍵存在,則向已有的數(shù)組末尾加入一個(gè)元素,鍵不存在則會(huì)創(chuàng)建一個(gè)新的數(shù)組。
3、upsert操作
upsert操作具有saveOrUpdate的功能,如果沒(méi)有文檔符合更新條件,則以更新條件和更新文檔為基礎(chǔ)創(chuàng)建一個(gè)新的文檔。如果有符合更新條件的文檔,則正常更新。創(chuàng)建新文檔時(shí)會(huì)以條件文檔作為基礎(chǔ),將修改器作用其之上。upsert操作是原子性的,高效的。
4、批量更新
批量更新只需將update的第4個(gè)參數(shù)設(shè)為true即可。
四、瞬間完成
上面的插入,刪除和更新操作都是瞬間完成的,它們不需要等待數(shù)據(jù)庫(kù)響應(yīng)。這樣的實(shí)現(xiàn)可以獲取高性能,速度非???,只會(huì)受客戶端發(fā)送速度和網(wǎng)絡(luò)速度的制約。但由于不會(huì)獲取服務(wù)器狀態(tài),所以不能保證操作順利完成。這對(duì)于付費(fèi)系統(tǒng),安全性較高的系統(tǒng)是不可行的,此時(shí)對(duì)這些操作需要使用它們的安全版本。安全版本會(huì)在操作執(zhí)行后立即運(yùn)行g(shù)etLastError命令,來(lái)檢查是否執(zhí)行成功。如果失敗一般會(huì)拋出可捕獲的異常,然后我們可以在代碼中處理。
五、請(qǐng)求和連接
數(shù)據(jù)庫(kù)會(huì)為每個(gè)MongoDB數(shù)據(jù)庫(kù)連接創(chuàng)建一個(gè)隊(duì)列,存放這個(gè)連接的請(qǐng)求,客戶端新發(fā)送的請(qǐng)求會(huì)被放到隊(duì)列的末尾。只有隊(duì)列中的請(qǐng)求都執(zhí)行完畢,后續(xù)的請(qǐng)求才會(huì)執(zhí)行。即對(duì)于單個(gè)連接來(lái)說(shuō),請(qǐng)求都是順序執(zhí)行不存在并發(fā)問(wèn)題,所以它總能讀到自己寫的東西。但對(duì)于不同的連接就有可能出現(xiàn)讀取和寫入不一致的問(wèn)題,在驅(qū)動(dòng)程序使用連接池時(shí)要特別注意此行為。具體連接池信息可參考官網(wǎng):MongoDB官網(wǎng)
您可能感興趣的文章:- 詳解MongoDB數(shù)據(jù)庫(kù)基礎(chǔ)操作及實(shí)例
- 老生常談MongoDB數(shù)據(jù)庫(kù)基礎(chǔ)操作
- mongodb數(shù)據(jù)庫(kù)基礎(chǔ)知識(shí)之連表查詢
- PHP中MongoDB數(shù)據(jù)庫(kù)的連接、添加、修改、查詢、刪除等操作實(shí)例
- mongodb 數(shù)據(jù)庫(kù)操作詳解--創(chuàng)建,切換,刪除
- mongodb 數(shù)據(jù)庫(kù)操作--備份 還原 導(dǎo)出 導(dǎo)入
- MongoDB數(shù)據(jù)庫(kù)文檔操作方法(必看篇)
- MongoDB模糊查詢操作案例詳解(類關(guān)系型數(shù)據(jù)庫(kù)的 like 和 not like)
- mongoDB4.0數(shù)據(jù)庫(kù)的操作方法
- mongodb數(shù)據(jù)庫(kù)入門學(xué)習(xí)筆記之下載、安裝、啟動(dòng)、連接操作解析
- MongoDB數(shù)據(jù)庫(kù)安裝配置、基本操作實(shí)例詳解
- MongoDB數(shù)據(jù)庫(kù)基礎(chǔ)操作總結(jié)