01.Mongodb入門(mén)

MongoDB

一晾腔、Mongodb介紹

1). 簡(jiǎn)介

跨平臺(tái)的财破,面向文檔的數(shù)據(jù)庫(kù);介于關(guān)系數(shù)據(jù)庫(kù)和非關(guān)系數(shù)據(jù)庫(kù)之間,是非關(guān)系數(shù)據(jù)庫(kù)當(dāng)中功能最豐富维费,最像關(guān)系數(shù)據(jù)庫(kù)的產(chǎn)品。它支持的數(shù)據(jù)結(jié)構(gòu)非常松散促王,是類似JSON 的 BSON 格式,可以存儲(chǔ)比較復(fù)雜的數(shù)據(jù)類型;

2). 特點(diǎn)

支持的查詢語(yǔ)言非常強(qiáng)大犀盟,其語(yǔ)法有點(diǎn)類似于面向?qū)ο蟮牟樵冋Z(yǔ)言,幾乎可以實(shí)現(xiàn)類似關(guān)系數(shù)據(jù)庫(kù)單表查詢的絕大部分功能蝇狼,而且還支持對(duì)數(shù)據(jù)建立索引阅畴。它是一個(gè)面向集合的,模式自由的文檔型數(shù)據(jù)庫(kù)

推薦學(xué)習(xí)網(wǎng)站 http://www.runoob.com/mongodb/mongodb-tutorial.html

  1. 面向集合存儲(chǔ),易于存儲(chǔ)對(duì)象類型的數(shù)據(jù)
  2. 模式自由
  3. 支持動(dòng)態(tài)查詢
  4. 支持完全索引迅耘,包含內(nèi)部對(duì)象
  5. 支持復(fù)制和故障恢復(fù)
  6. 使用高效的二進(jìn)制數(shù)據(jù)存儲(chǔ)贱枣,包括大型對(duì)象(如視頻等)
  7. 自動(dòng)處理碎片监署,以支持云計(jì)算層次的擴(kuò)展性
  8. 支持 Python,PHP纽哥,Ruby钠乏,Java,C春塌,C#晓避,Javascript,Perl 及 C++語(yǔ)言的驅(qū)動(dòng)程序只壳,社區(qū)中也提供了對(duì) Erlang 及.NET 等平臺(tái)的驅(qū)動(dòng)程序
  9. 文件存儲(chǔ)格式為 BSON(一種 JSON 的擴(kuò)展)

3). 體系

文檔(document)俏拱、集合(collection)、數(shù)據(jù)庫(kù)(database)三部分組成的吼句。邏輯結(jié)構(gòu)是面向用戶

  1. MongoDB 的文檔(document)锅必,相當(dāng)于關(guān)系數(shù)據(jù)庫(kù)中的一行記錄。
  2. 多個(gè)文檔組成一個(gè)集合(collection)惕艳,相當(dāng)于關(guān)系數(shù)據(jù)庫(kù)的表搞隐。
  3. 多個(gè)集合(collection),邏輯上組織在一起尔艇,就是數(shù)據(jù)庫(kù)(database)尔许。
  4. 一個(gè) MongoDB 實(shí)例支持多個(gè)數(shù)據(jù)庫(kù)(database)

mongodb.png

4). 開(kāi)發(fā)環(huán)境安裝【win環(huán)境】

下載 類似于 mongodb-win32-x86_64-2008plus-ssl-3.2.10-signed.msi 的安裝包,雙擊安裝终娃!將安裝的路徑下的/bin設(shè)置到系統(tǒng)環(huán)境變量path之下,方便啟動(dòng)蒸甜!

5). 啟動(dòng)服務(wù)

1】cmd打開(kāi)命令,創(chuàng)建一個(gè)存放數(shù)據(jù)目錄

d:
md data\db

2】啟動(dòng)服務(wù)棠耕,指定數(shù)據(jù)存儲(chǔ)/訪問(wèn)目錄

mongod --dbpath=d:\data\db
  1. 默認(rèn)端口為 27017
  2. 指定端口啟動(dòng)方式
mongod --port 12306 --dbpath=d:\data\db

3】登陸系統(tǒng),新打開(kāi)一個(gè)cmd

  1. 如果是默認(rèn)端口啟動(dòng)柠新,而且是部署在本機(jī);默認(rèn)連接 test 數(shù)據(jù)庫(kù)
mongo
  1. 連接遠(yuǎn)程
mongo ip地址
mongo ip地址:port端口

二窍荧、Mongodb基本操作

1). 創(chuàng)建并切換數(shù)據(jù)庫(kù)

使用use 數(shù)據(jù)庫(kù)名稱即可選擇數(shù)據(jù)庫(kù),如果該數(shù)據(jù)庫(kù)不存在會(huì)自動(dòng)創(chuàng)建

use lingtingdb

2). 插入文檔 save()

db.student 表示使用當(dāng)前數(shù)據(jù)庫(kù)下的student集合恨憎,如果不存在則會(huì)創(chuàng)建蕊退!

  1. 定義變量方式
r = {name:'孫悟空', sex:'男',age:30,address:'花果山水簾洞'};
db.student.save(r);
  1. 直接插入
db.student.save({name:"豬八戒",sex:"男",age:28,address:"高老莊旅游度假村"});
  1. 默認(rèn)會(huì)插入ObjectID類型的_id字段,當(dāng)然可以指定MongoDB支持的任意類型
db.student.save({_id:1, name:"紅孩兒",sex:"男",age:16,address:"火云洞"});
  1. 批量插入
db.love.save([{name:"曉慶",age:18,gender:"女"},{name:"xiaoqing",age:18,gender:"女"},{name:"曉慶",age:18,gender:"女"}]);

3). 簡(jiǎn)單查詢集合 find()

  1. 查詢?nèi)?/li>
db.student.find();
  1. 條件查詢
db.student.find({sex:"女"});
  1. 條件查詢第一條數(shù)據(jù)
db.student.findOne({sex:"男"});
  1. 限制查詢的條數(shù)【配合跳躍查詢可以實(shí)現(xiàn)分頁(yè)查詢】
db.student.find().limit(3);
  1. 跳躍查詢【配合限制查詢可以實(shí)現(xiàn)分頁(yè)查詢】
db.student.find().skip(1).limit(3);
  1. 分頁(yè)查詢語(yǔ)法
db.student.find(條件).skip((查詢的頁(yè)碼 - 1) * 每頁(yè)數(shù)量).limit(每頁(yè)查詢的數(shù)量);
  1. 投影查詢

只顯示name和age兩個(gè)key憔恳,_id主鍵不顯示瓤荔。

db.student.find({"name":"light"},{name:1,age:1,_id:0})

4). 修改文檔 $set

  1. 【*】錯(cuò)誤的修改方式【*】,導(dǎo)致該條數(shù)據(jù)只含有age字段(_id字段會(huì)保留,一般_id字段不考慮)
db.student.update({name:"孫悟空"},{age:31});
  1. 條件修改,第一個(gè)參數(shù)為條件钥组,第二個(gè)參數(shù)為被修改的值
db.student.update({name:"豬八戒",age:25},{$set:{address:"高老莊旅游度假村1",age:49}});

5). 刪除文檔 remove()

  1. 條件刪除【刪除匹配的所有結(jié)果】
    db.student.remove({name:"哪吒"})

  2. 只刪除匹配的一條

db.student.remove({name:"豬八戒"},{justOne:true});

三输硝、Mongodb高級(jí)查詢

1). 模糊查詢

  1. 正則查詢包含的字符串
db.student.find({name:/白/});
  1. 正則查詢以什么開(kāi)頭
db.student.find({name:/^白/});

2). null值處理

這種查詢會(huì)查詢出該字段為null的以及不存在該字段的文檔記錄。

> db.student.update({name:"唐僧"},{$set:{address:null}});

> db.student.find({address:null});

3). 大于小于不等于

  1. 大于
// 大于: field > value
db.collection.find({ "field" : { $gt: value } } );
  1. 大于等于
// 大于等于: field >= value
db.collection.find({ "field" : { $gte: value } } );
  1. 小于
// 小于: field < value
db.collection.find({ "field" : { $lt: value } } );
  1. 小于等于
// 小于等于: field <= value
db.collection.find({"field":{ $lte: value } } );
  1. 不等于
db.student.find({sex:{$ne:"男"}});

4). 判斷字段是否存在

db.student.find({address:{$exists:true}});

db.student.find({address:{$exists:false}});

5). 包含與不包含

  1. 包含
db.student.find({age:{$in:[20,25,30]}});
  1. 不包含
db.student.find({age:{$nin:[20,25,30]}});

6). 統(tǒng)計(jì)記錄條數(shù)

db.student.count();

db.student.count({age:{$lte:20}});

7). 條件連接

  1. 【并且】需要查詢同時(shí)滿足兩個(gè)以上條件程梦,需要使用and操作符將條件進(jìn)行關(guān)聯(lián) `and:[ { },{ },{ } ]`
// 查詢student集合中age大于等于20 并且age小于30的文檔
db.student.find({$and:[{age:{$gte:20}},{age:{$lt:30}}]});
  1. 兩個(gè)以上條件之間是或者的關(guān)系点把,我們使用or操作符進(jìn)行關(guān)聯(lián)橘荠,與前面and的使用方式相同 格式為:$or:[ { },{ },{ } ]
// 查詢student集合中sex為女,或者年齡小于20的文檔記錄
db.student.find({$or:[{sex:"女"},{age:{$lt:20}}]});
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末郎逃,一起剝皮案震驚了整個(gè)濱河市哥童,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌褒翰,老刑警劉巖贮懈,帶你破解...
    沈念sama閱讀 221,430評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異影暴,居然都是意外死亡错邦,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,406評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門(mén)型宙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)撬呢,“玉大人,你說(shuō)我怎么就攤上這事妆兑』昀梗” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 167,834評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵搁嗓,是天一觀的道長(zhǎng)芯勘。 經(jīng)常有香客問(wèn)我,道長(zhǎng)腺逛,這世上最難降的妖魔是什么荷愕? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,543評(píng)論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮棍矛,結(jié)果婚禮上安疗,老公的妹妹穿的比我還像新娘。我一直安慰自己够委,他們只是感情好荐类,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,547評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著茁帽,像睡著了一般玉罐。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上潘拨,一...
    開(kāi)封第一講書(shū)人閱讀 52,196評(píng)論 1 308
  • 那天吊输,我揣著相機(jī)與錄音,去河邊找鬼战秋。 笑死璧亚,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播癣蟋,決...
    沈念sama閱讀 40,776評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼透硝,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了疯搅?” 一聲冷哼從身側(cè)響起濒生,我...
    開(kāi)封第一講書(shū)人閱讀 39,671評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎幔欧,沒(méi)想到半個(gè)月后罪治,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,221評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡礁蔗,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,303評(píng)論 3 340
  • 正文 我和宋清朗相戀三年觉义,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片浴井。...
    茶點(diǎn)故事閱讀 40,444評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡晒骇,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出磺浙,到底是詐尸還是另有隱情洪囤,我是刑警寧澤,帶...
    沈念sama閱讀 36,134評(píng)論 5 350
  • 正文 年R本政府宣布撕氧,位于F島的核電站瘤缩,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏伦泥。R本人自食惡果不足惜剥啤,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,810評(píng)論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望不脯。 院中可真熱鬧铐殃,春花似錦、人聲如沸跨新。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,285評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)域帐。三九已至,卻和暖如春是整,著一層夾襖步出監(jiān)牢的瞬間肖揣,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,399評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工浮入, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留龙优,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,837評(píng)論 3 376
  • 正文 我出身青樓事秀,卻偏偏與公主長(zhǎng)得像彤断,于是被迫代替她去往敵國(guó)和親野舶。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,455評(píng)論 2 359

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

  • 一宰衙、MongoDB簡(jiǎn)介 1.概述 ? MongoDB是一個(gè)基于分布式文件存儲(chǔ)的數(shù)據(jù)庫(kù)平道,由C++語(yǔ)言編寫(xiě)。旨在為WE...
    鄭元吉閱讀 978評(píng)論 0 2
  • 1. MongoDB 簡(jiǎn)介 MongoDB是一個(gè)可擴(kuò)展的高性能供炼,開(kāi)源一屋,模式自由,面向文檔的NoSQL袋哼,基于分布式文...
    rhlp閱讀 1,118評(píng)論 0 3
  • 簡(jiǎn)介 MongoDB 是一個(gè)基于分布式文件存儲(chǔ)的NoSQL數(shù)據(jù)庫(kù) 由C++語(yǔ)言編寫(xiě)冀墨,運(yùn)行穩(wěn)定,性能高 旨在為 WE...
    大熊_7d48閱讀 37,293評(píng)論 1 9
  • NoSql數(shù)據(jù)庫(kù)優(yōu)缺點(diǎn) 在優(yōu)勢(shì)方面主要體現(xiàn)在下面幾點(diǎn): 簡(jiǎn)單的擴(kuò)展 快速的讀寫(xiě) 低廉的成本 靈活的數(shù)據(jù)模型 在不足...
    dreamer_lk閱讀 2,735評(píng)論 0 6
  • 昨天一個(gè)老人家到我們這里賣木耳涛贯,剛開(kāi)始說(shuō)40元一袋诽嘉,我們好幾個(gè)人合伙買,每人35元疫蔓。老人家沒(méi)有微信含懊,只能付...
    99號(hào)渡老師閱讀 294評(píng)論 0 0