MongoDB 使用法則

一 ? 安裝

1.下載

$ brew install mongodb

2.啟動(dòng)

?$ mongod --config /usr/local/etc/mongod.conf

3.連接

?$ mongo ?

二 ? 語(yǔ)法

show dbs ?查看所有數(shù)據(jù)庫(kù)

db.createCollection('col') 創(chuàng)建col集合

use DBNAME ?創(chuàng)建并切換至某某數(shù)據(jù)庫(kù)

db.dropDatabase() ?刪除當(dāng)前數(shù)據(jù)庫(kù)

db.collection.drop() ? 刪除集合

show ?tables ? 查看所有集合

db.Collection_Name.insert(document) ?插入文檔

db.Collection_Name.find() ? 查看文檔

db.Collection_Name.update(<query>,<update>,{upsert:false ? 是否插入不存在的數(shù)據(jù)摔笤,multi:false ?只更新查到的第一個(gè)數(shù)據(jù) ? ?writeConcern:拋出異常的級(jí)別}

db.collection.save(<document>,{writeConcern:級(jí)別} ?save() 方法通過(guò)傳入的文檔來(lái)替換已有的文檔

db.collection.remove(<query>,{justOne:true ? 只刪除一個(gè)文檔}

db.collection.find().pretty() ?查詢集合中的數(shù)據(jù)

db.col.find({"likes":{$lt:50}}).pretty() ? 小于

db.col.find({"likes":{$lte:50}}).pretty() ? 小于等于

db.col.find({"likes":{$gt:50}}).pretty() ? 大于

db.col.find({"like":{$gte:50}}}.pretty() ? 大于等于

db.col.find({"likes":{$ne:50}}).pretty() ? 不等于

AND條件? db.col.find({key1:value1,key2:value2}).pretty()

OR條件 ? db.col.find({$or:[{key1:value1}, {key2:value2}]}).pretty()

AND? OR 組合? db.col.find({"likes":{$gt:50},$or:[{"by":"菜鳥(niǎo)教程"},{"title":"MongoDB 教程"}]}).pretty()

db.col.find({"title":{$type:2}}) ? $type條件操作符 Double ?1; String 2; Object 3;Array 4;Binary data 5; Undefined 6;Object id 7; Boolean 8; Date 9;Null 10; Regular Expression 11; Javascript 13; Symbol 14; Timestamp 17;

db.collection.find().limit(NUMBER) ?讀取指定數(shù)量的數(shù)據(jù)記錄

db.col.find({},{"title":1,_id:0}).limit(1).skip(1)? 跳過(guò)指定的條數(shù)败潦,最先執(zhí)行順序 sort再skip再limit

db.col.find({},{"title":1,_id:0}).sort({"likes":-1}) ?1正序;-1倒序

索引 ?ensureIndex()

db.COLLECTION_NAME.ensureIndex({KEY:1},option) ?1為升序創(chuàng)建索引 ?-1為降序創(chuàng)建索引 ? ?option可選參數(shù){background:false ?防止創(chuàng)建索引會(huì)阻塞其他數(shù)據(jù)庫(kù)操作,將其指定為true尔许;.......}

db.col.ensureIndex({"title":1,"description":-1}) ?可以設(shè)置多個(gè)索引 ??

db.values.ensureIndex({open:1,close:1},{background:true})

聚合aggregate()方法用于處理數(shù)據(jù)挎塌,并返回計(jì)算后的結(jié)果

db.COLLECTION_NAME.aggregate(AGGREGATE_OPERATION)

db.mycol.aggregate([{$group:{_id:"$by_user",num_tutorial:{$sum:"$likes"}}}])

$sum ?計(jì)算總和采缚; $avg 計(jì)算平均值嘴脾;$min 獲取集合中所有文檔對(duì)應(yīng)的最小值; $max 最大值洛搀; $push 在結(jié)果文檔中插入值 到 一個(gè)數(shù)組中敢茁;$addToSet 在結(jié)果文檔中插入值到一個(gè)數(shù)組中,但不創(chuàng)建副本留美;$first ?根據(jù)資源文檔的排序獲取第一個(gè)文檔數(shù)據(jù)彰檬;$last ?最后一個(gè)文檔數(shù)據(jù);

管道 將在一個(gè)管道處理完的結(jié)果 傳遞給下一個(gè)管道處理独榴;表達(dá)式:處理輸入文檔并輸出僧叉。表達(dá)式是無(wú)狀態(tài)的奕枝,只能用于計(jì)算當(dāng)前聚合管道的文檔:

$project 修改輸入文檔的結(jié)構(gòu)棺榔;$match 用于過(guò)濾數(shù)據(jù);$limit 限制聚合管道返回的文檔數(shù)隘道;$skip ?跳過(guò)指定文檔的數(shù)量症歇;$unwind 將文檔中的某一個(gè)數(shù)組類型字段拆分成多條郎笆,每條包含數(shù)組中的一個(gè)值。$group:將集合中的文檔分組忘晤,可用于統(tǒng)計(jì)結(jié)果宛蚓;$sort:排序;$geoNear:輸出接近某一地理位置的有序文檔设塔。

分片:存在的另一種集群凄吏,可以滿足MongoDB數(shù)據(jù)量大量增長(zhǎng)的需求。

備份:mongodump -h dbhost -d dbname -o dbdirectory

恢復(fù)數(shù)據(jù):mongorestore -h <hostname><:port> -d ?dbname <path>

監(jiān)控:/bin ? $mongostat

? ? ? ? ? ? ? ? ? ?$mongotop

關(guān)系類型:嵌入式關(guān)系--保存在單一的文檔中闰蛔,比較容易獲取和維護(hù)數(shù)據(jù)痕钢,但不斷增大會(huì)影響讀寫性能。

? ? ? ? ? ? ? ? ? 引用式關(guān)系--把數(shù)據(jù)文檔和用戶文檔分開(kāi)序六,通過(guò)文檔的ID字段來(lái)建立關(guān)系任连。{"name":"Tom Benzamin","address_ids":[ObjectId("52ffc4a5d85242602e000000"),ObjectId("52ffc4a5d85242602e000001")]}

使用DBRefs:一個(gè)文檔沖多個(gè)集合中引用文檔。{$ref:.集合名稱. ,$id: ..引用ID..,$db:.數(shù)據(jù)庫(kù)名稱..}

原子操作:MongoDB提供了許多原子操作例诀,比如文檔的保存随抠、修改、刪除繁涂。(原子操作:要么這個(gè)文檔保存到mongoDB拱她,要么沒(méi)有保存到MongoDB,不會(huì)出現(xiàn)查詢到的文檔沒(méi)有保存完整的情況)

ObjectID 是一個(gè)12字節(jié)BSON類型數(shù)據(jù)扔罪,前4個(gè)字節(jié)表示時(shí)間戳椭懊,3個(gè)字節(jié)是機(jī)器標(biāo)識(shí)碼,2個(gè)是進(jìn)程ID步势,最后3個(gè)字節(jié)是隨機(jī)數(shù)

newObjectId = ObjectId()

new ObjectId().str

正則表達(dá)式post_text

db.posts.find({post_text:{$regex:"runoob"}})? 或db.posts.find({post_text:/runoob/}) 或 db.posts.find({post_text:{$regex:"runoob",$options:"$i"}})

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末氧猬,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子坏瘩,更是在濱河造成了極大的恐慌盅抚,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,718評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件倔矾,死亡現(xiàn)場(chǎng)離奇詭異妄均,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)哪自,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門丰包,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人壤巷,你說(shuō)我怎么就攤上這事邑彪。” “怎么了胧华?”我有些...
    開(kāi)封第一講書人閱讀 158,207評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵寄症,是天一觀的道長(zhǎng)宙彪。 經(jīng)常有香客問(wèn)我,道長(zhǎng)有巧,這世上最難降的妖魔是什么释漆? 我笑而不...
    開(kāi)封第一講書人閱讀 56,755評(píng)論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮篮迎,結(jié)果婚禮上男图,老公的妹妹穿的比我還像新娘。我一直安慰自己甜橱,他們只是感情好享言,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,862評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著渗鬼,像睡著了一般览露。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上譬胎,一...
    開(kāi)封第一講書人閱讀 50,050評(píng)論 1 291
  • 那天差牛,我揣著相機(jī)與錄音,去河邊找鬼堰乔。 笑死偏化,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的镐侯。 我是一名探鬼主播侦讨,決...
    沈念sama閱讀 39,136評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼苟翻!你這毒婦竟也來(lái)了韵卤?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 37,882評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤崇猫,失蹤者是張志新(化名)和其女友劉穎沈条,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體诅炉,經(jīng)...
    沈念sama閱讀 44,330評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蜡歹,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,651評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了涕烧。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片月而。...
    茶點(diǎn)故事閱讀 38,789評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖议纯,靈堂內(nèi)的尸體忽然破棺而出父款,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 34,477評(píng)論 4 333
  • 正文 年R本政府宣布铛漓,位于F島的核電站溯香,受9級(jí)特大地震影響鲫构,放射性物質(zhì)發(fā)生泄漏浓恶。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,135評(píng)論 3 317
  • 文/蒙蒙 一结笨、第九天 我趴在偏房一處隱蔽的房頂上張望包晰。 院中可真熱鬧,春花似錦炕吸、人聲如沸伐憾。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,864評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)树肃。三九已至,卻和暖如春瀑罗,著一層夾襖步出監(jiān)牢的瞬間胸嘴,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,099評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工斩祭, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留劣像,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,598評(píng)論 2 362
  • 正文 我出身青樓摧玫,卻偏偏與公主長(zhǎng)得像耳奕,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子诬像,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,697評(píng)論 2 351

推薦閱讀更多精彩內(nèi)容