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
- 面向集合存儲(chǔ),易于存儲(chǔ)對(duì)象類型的數(shù)據(jù)
- 模式自由
- 支持動(dòng)態(tài)查詢
- 支持完全索引迅耘,包含內(nèi)部對(duì)象
- 支持復(fù)制和故障恢復(fù)
- 使用高效的二進(jìn)制數(shù)據(jù)存儲(chǔ)贱枣,包括大型對(duì)象(如視頻等)
- 自動(dòng)處理碎片监署,以支持云計(jì)算層次的擴(kuò)展性
- 支持 Python,PHP纽哥,Ruby钠乏,Java,C春塌,C#晓避,Javascript,Perl 及 C++語(yǔ)言的驅(qū)動(dòng)程序只壳,社區(qū)中也提供了對(duì) Erlang 及.NET 等平臺(tái)的驅(qū)動(dòng)程序
- 文件存儲(chǔ)格式為 BSON(一種 JSON 的擴(kuò)展)
3). 體系
由 文檔(document)俏拱、集合(collection)、數(shù)據(jù)庫(kù)(database)三部分組成的吼句。邏輯結(jié)構(gòu)是面向用戶
- MongoDB 的文檔(document)锅必,相當(dāng)于關(guān)系數(shù)據(jù)庫(kù)中的一行記錄。
- 多個(gè)文檔組成一個(gè)集合(collection)惕艳,相當(dāng)于關(guān)系數(shù)據(jù)庫(kù)的表搞隐。
- 多個(gè)集合(collection),邏輯上組織在一起尔艇,就是數(shù)據(jù)庫(kù)(database)尔许。
- 一個(gè) MongoDB 實(shí)例支持多個(gè)數(shù)據(jù)庫(kù)(database)
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
- 默認(rèn)端口為 27017
- 指定端口啟動(dòng)方式
mongod --port 12306 --dbpath=d:\data\db
3】登陸系統(tǒng),新打開(kāi)一個(gè)cmd
- 如果是默認(rèn)端口啟動(dòng)柠新,而且是部署在本機(jī);默認(rèn)連接
test
數(shù)據(jù)庫(kù)
mongo
- 連接遠(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)建蕊退!
- 定義變量方式
r = {name:'孫悟空', sex:'男',age:30,address:'花果山水簾洞'};
db.student.save(r);
- 直接插入
db.student.save({name:"豬八戒",sex:"男",age:28,address:"高老莊旅游度假村"});
- 默認(rèn)會(huì)插入ObjectID類型的
_id
字段,當(dāng)然可以指定MongoDB支持的任意類型
db.student.save({_id:1, name:"紅孩兒",sex:"男",age:16,address:"火云洞"});
- 批量插入
db.love.save([{name:"曉慶",age:18,gender:"女"},{name:"xiaoqing",age:18,gender:"女"},{name:"曉慶",age:18,gender:"女"}]);
3). 簡(jiǎn)單查詢集合 find()
- 查詢?nèi)?/li>
db.student.find();
- 條件查詢
db.student.find({sex:"女"});
- 條件查詢第一條數(shù)據(jù)
db.student.findOne({sex:"男"});
- 限制查詢的條數(shù)【配合跳躍查詢可以實(shí)現(xiàn)分頁(yè)查詢】
db.student.find().limit(3);
- 跳躍查詢【配合限制查詢可以實(shí)現(xiàn)分頁(yè)查詢】
db.student.find().skip(1).limit(3);
- 分頁(yè)查詢語(yǔ)法
db.student.find(條件).skip((查詢的頁(yè)碼 - 1) * 每頁(yè)數(shù)量).limit(每頁(yè)查詢的數(shù)量);
- 投影查詢
只顯示name和age兩個(gè)key憔恳,_id主鍵不顯示瓤荔。
db.student.find({"name":"light"},{name:1,age:1,_id:0})
4). 修改文檔 $set
- 【*】錯(cuò)誤的修改方式【*】,導(dǎo)致該條數(shù)據(jù)只含有age字段(_id字段會(huì)保留,一般_id字段不考慮)
db.student.update({name:"孫悟空"},{age:31});
- 條件修改,第一個(gè)參數(shù)為條件钥组,第二個(gè)參數(shù)為被修改的值
db.student.update({name:"豬八戒",age:25},{$set:{address:"高老莊旅游度假村1",age:49}});
5). 刪除文檔 remove()
條件刪除【刪除匹配的所有結(jié)果】
db.student.remove({name:"哪吒"})只刪除匹配的一條
db.student.remove({name:"豬八戒"},{justOne:true});
三输硝、Mongodb高級(jí)查詢
1). 模糊查詢
- 正則查詢包含的字符串
db.student.find({name:/白/});
- 正則查詢以什么開(kāi)頭
db.student.find({name:/^白/});
2). null值處理
這種查詢會(huì)查詢出該字段為null的以及不存在該字段的文檔記錄。
> db.student.update({name:"唐僧"},{$set:{address:null}});
> db.student.find({address:null});
3). 大于小于不等于
- 大于
// 大于: field > value
db.collection.find({ "field" : { $gt: value } } );
- 大于等于
// 大于等于: field >= value
db.collection.find({ "field" : { $gte: value } } );
- 小于
// 小于: field < value
db.collection.find({ "field" : { $lt: value } } );
- 小于等于
// 小于等于: field <= value
db.collection.find({"field":{ $lte: value } } );
- 不等于
db.student.find({sex:{$ne:"男"}});
4). 判斷字段是否存在
db.student.find({address:{$exists:true}});
db.student.find({address:{$exists:false}});
5). 包含與不包含
- 包含
db.student.find({age:{$in:[20,25,30]}});
- 不包含
db.student.find({age:{$nin:[20,25,30]}});
6). 統(tǒng)計(jì)記錄條數(shù)
db.student.count();
db.student.count({age:{$lte:20}});
7). 條件連接
- 【并且】需要查詢同時(shí)滿足兩個(gè)以上條件程梦,需要使用
and:[ { },{ },{ } ]`
// 查詢student集合中age大于等于20 并且age小于30的文檔
db.student.find({$and:[{age:{$gte:20}},{age:{$lt:30}}]});
- 兩個(gè)以上條件之間是或者的關(guān)系点把,我們使用
and的使用方式相同 格式為:
$or:[ { },{ },{ } ]
// 查詢student集合中sex為女,或者年齡小于20的文檔記錄
db.student.find({$or:[{sex:"女"},{age:{$lt:20}}]});