mongodb(入門(mén))

1.express

node Web應(yīng)用框架面哼,提供了很多Web應(yīng)用和HTTP工具

使用express可以快速搭建一個(gè)完整功能的網(wǎng)站

需要安裝

npm install express
引入模塊贬媒,創(chuàng)建對(duì)象
// 引入模塊,并創(chuàng)建對(duì)象

var  express  = require('express');
var  app  =  express ();

一:核心功能

路由

app.get("/", function (req, res) {

    res.send("哈哈哈");

});

app.listen(8888);
app.get("/index.html", function (req, res) {

    res.sendfile(__dirname + "/index.html");

}).listen(8888);

服務(wù)端

// 處理get方式發(fā)送的請(qǐng)求

app.get("/", function (req, res) {

    // 返回一個(gè)靜態(tài)文件

    res.sendfile(__dirname + "/index.html");

});

app.get("/list", function (req, res) {

    // 返回一個(gè)字符串

    res.send("get" + req.url);

});


app.post("/list", function (req, res) {

    res.send("post" + req.url);

});


// all就是處理不管任何方式發(fā)送的請(qǐng)求,*為任意路徑

app.all("*", function (req, res) {

    res.send("Welcome To Express");

});

// 設(shè)置端口
app.listen(8888);

獲取請(qǐng)求的參數(shù)

console.log(req.host); // 獲取主機(jī)名

console.log(req.path); // 獲取url的路徑

console.log(req.query); // 獲取客戶(hù)端get請(qǐng)求路徑的參數(shù)

返回值

res.send("返回字符串");

res.sendFile(__dirname + "/index.html");

res.sendStatus(200);

其他

---http://www.runoob.com/nodejs/nodejs-express-framework.html

---https://www.zybuluo.com/XiangZhou/note/208532

---模板引擎

---cookie

---中間件

2.mongodb

官網(wǎng)
https://www.mongodb.com/

介紹

一颖低、什么是MongoDB ?
1、MongoDB 是由C++語(yǔ)言編寫(xiě)的,是一個(gè)基于分布式文件存儲(chǔ)的開(kāi)源數(shù)據(jù)庫(kù)系統(tǒng)汹族。在高負(fù)載的情況下讼昆,添加更多的節(jié)點(diǎn)托享,可以保證服務(wù)器性能。
2浸赫、MongoDB 旨在為WEB應(yīng)用提供可擴(kuò)展的高性能數(shù)據(jù)存儲(chǔ)解決方案闰围。
3、MongoDB 將數(shù)據(jù)存儲(chǔ)為一個(gè)文檔既峡,數(shù)據(jù)結(jié)構(gòu)由鍵值(key=>value)對(duì)組成羡榴。MongoDB 文檔類(lèi)似于 JSON 對(duì)象。字段值可以包含其他文檔运敢,數(shù)組及文檔數(shù)組校仑。
二、歷史
1传惠、2007年10月迄沫,MongoDB由10gen團(tuán)隊(duì)所發(fā)展。2009年2月首度推出卦方。
2羊瘩、2012年05月23日,MongoDB2.1 開(kāi)發(fā)分支發(fā)布了! 該版本采用全新架構(gòu)愿汰,包含諸多增強(qiáng)困后。
3、2012年06月06日衬廷,MongoDB 2.0.6 發(fā)布摇予,分布式文檔數(shù)據(jù)庫(kù)。
4吗跋、2013年04月23日侧戴,MongoDB 2.4.3 發(fā)布,此版本包括了一些性能優(yōu)化跌宛,功能增強(qiáng)以及bug修復(fù)酗宋。
5、2013年08月20日疆拘,MongoDB 2.4.6 發(fā)布蜕猫,是目前最新的穩(wěn)定版。
三哎迄、主要特點(diǎn)
1回右、MongoDB的提供了一個(gè)面向文檔存儲(chǔ)隆圆,基本的思路就是將原來(lái)“行”的概念換成更加靈活的“文檔”模型。一條記錄可以表示非常復(fù)雜的層次關(guān)系翔烁。
2渺氧、Mongo支持豐富的查詢(xún)表達(dá)式。查詢(xún)指令使用JSON形式的標(biāo)記蹬屹,可輕易查詢(xún)文檔中內(nèi)嵌的對(duì)象及數(shù)組侣背。

3、非常容易擴(kuò)展慨默。面對(duì)數(shù)據(jù)量的不斷上漲贩耐,通常有兩種方案,一種是購(gòu)買(mǎi)更好的硬件业筏,別一種是分散數(shù)據(jù)憔杨,進(jìn)行分布式的擴(kuò)展,前者有著非常大的缺點(diǎn)蒜胖,因 為硬件通常是有物理極限的消别,當(dāng)達(dá)到極限以后,處理能力就不可能再進(jìn)行擴(kuò)展了台谢。所以建議的方式是使用集群進(jìn)行擴(kuò)展寻狂。MongoDB所采用的面向文檔的數(shù)據(jù)模 型使其可以自動(dòng)在多臺(tái)服務(wù)器之間分割數(shù)據(jù)。它還可以平衡集群的數(shù)據(jù)和負(fù)載朋沮,自動(dòng)重排文檔蛇券。
4、MongoDB支持各種編程語(yǔ)言:RUBY樊拓,PYTHON纠亚,JAVA,C++筋夏,PHP蒂胞,C#等多種語(yǔ)言。
5条篷、豐富的功能骗随。包括索引、存儲(chǔ)JavaScript赴叹、聚合鸿染、固定集合、文件存儲(chǔ)等乞巧。
6涨椒、方便的管理,除了啟動(dòng)數(shù)據(jù)庫(kù)服務(wù)器之外,幾乎沒(méi)有什么必要的管理操作丢烘。管理集群只需要知道有新增加的節(jié)點(diǎn)柱宦,就會(huì)自動(dòng)集成和配置新節(jié)點(diǎn)些椒。

用C++編寫(xiě)的分布式來(lái)源數(shù)據(jù)庫(kù)系統(tǒng)
旨在為Web應(yīng)用提供可擴(kuò)展的高性能的解決方案
將數(shù)據(jù)存儲(chǔ)為文檔播瞳,類(lèi)似json

命令行使用

安裝
brew install mongodb
http://blog.sina.com.cn/s/blog_7c8dc2d50101lwka.html

可視化工具

Robomongo
https://robomongo.org/

概念解釋

專(zhuān)業(yè)術(shù)語(yǔ)展示

屏幕快照 2016-07-21 上午9.23.01.png

示例展示

屏幕快照 2016-07-21 上午9.23.11.png

保留關(guān)鍵字

1、一個(gè)mongodb中可以建立多個(gè)數(shù)據(jù)庫(kù)免糕。
2赢乓、MongoDB的單個(gè)實(shí)例可以容納多個(gè)獨(dú)立的數(shù)據(jù)庫(kù),每一個(gè)都有自己的集合和權(quán)限石窑,不同的數(shù)據(jù)庫(kù)也放置在不同的文件中牌芋。
3、數(shù)據(jù)庫(kù)也通過(guò)名字來(lái)標(biāo)識(shí)松逊。數(shù)據(jù)庫(kù)名可以是滿足以下條件的任意UTF-8字符串躺屁。
1.不能是空字符串(””)。
2.不得含有’ ‘(空格)经宏、.犀暑、$、/烁兰、\和\0 (空宇符)耐亏。
3.應(yīng)全部小寫(xiě)。
4.最多64字節(jié)沪斟。
4广辰、有一些數(shù)據(jù)庫(kù)名是保留的,可以直接訪問(wèn)這些有特殊作用的數(shù)據(jù)庫(kù)主之。

1.admin: 從權(quán)限的角度來(lái)看择吊,這是”root”數(shù)據(jù)庫(kù)。要是將一個(gè)用戶(hù)添加到這個(gè)數(shù)據(jù)庫(kù)槽奕,這個(gè)用戶(hù)自動(dòng)繼承所有數(shù)據(jù)庫(kù)的權(quán)限几睛。一些特定的服務(wù)器端命令也只能從這個(gè)數(shù)據(jù)庫(kù)運(yùn)行,比如列出所有的數(shù)據(jù)庫(kù)或者關(guān)閉服務(wù)器史翘。

2.local: 這個(gè)數(shù)據(jù)永遠(yuǎn)不會(huì)被復(fù)制枉长,可以用來(lái)存儲(chǔ)限于本地單臺(tái)服務(wù)器的任意集合 

3.config: 當(dāng)Mongo用于分片設(shè)置時(shí),config數(shù)據(jù)庫(kù)在內(nèi)部使用琼讽,用于保存分片的相關(guān)信息必峰。

admin
local
config

數(shù)據(jù)類(lèi)型

屏幕快照 2016-07-21 下午2.03.55.png

終端啟動(dòng)

mongod --dbpath=path
啟動(dòng)數(shù)據(jù)庫(kù)之后,可以選擇使用可視化工具

基本操作
--創(chuàng)建數(shù)據(jù)庫(kù)

        use dbname
         如果數(shù)據(jù)庫(kù)不存在钻蹬,則創(chuàng)建數(shù)據(jù)庫(kù)吼蚁,否則是切換到該數(shù)據(jù)庫(kù)

--查看所有數(shù)據(jù)庫(kù)
--當(dāng)前正在使用的數(shù)據(jù)庫(kù)
--刪除數(shù)據(jù)庫(kù)
db.dropDatabase()
--斷開(kāi)連接
exit
--查看幫助
help

深入操作

操作集合(table)

查看當(dāng)前數(shù)據(jù)庫(kù)下所有集合
show collections

創(chuàng)建集合

db.createCollection(“name”)

刪除集合

db.person.drop()

文檔操作(row)

插入文檔

db.collection_name.insert({})
db.collection_name.insert([{}, {}, {}])
db.collection_name.save()

如果指定_id,則更新id,否則類(lèi)似insert

更新文檔
db.collection_name.update({}, {})

update()方法用于更新已存在的文檔
語(yǔ)法
db.collection.update(
   <query>,
   <update>,
   {
     upset: <boolean>,
     multi: <boolean>,
     writeConcern: <document>
   }
)

參數(shù)說(shuō)明:
query : update的查詢(xún)條件肝匆,類(lèi)似sql update查詢(xún)內(nèi)where后面的粒蜈。
update : update的對(duì)象和一些更新的操作符(如$set,$inc...)等 $inc在原基礎(chǔ)上累加后更新   $set直接更新
upsert  : 可選,這個(gè)參數(shù)的意思是旗国,如果不存在update的記錄枯怖,是否插入objNew,true為插入,默認(rèn)是false能曾,不插入度硝。
multi  : 可選,mongodb 默認(rèn)是false,只更新找到的第一條記錄寿冕,如果這個(gè)參數(shù)為true,就把按條件查出來(lái)多條記錄全部更新蕊程。
writeConcern  :可選,拋出異常的級(jí)別驼唱。
實(shí)例
db.worker.update({name:’liSi’},{$set:{name:’liSi_update’}}) 將document數(shù)據(jù)中name是liSi 的數(shù)據(jù)的name修改為liSi_update
注:如果有多條name是liSi的數(shù)據(jù)只更新一條

db.worker.update({name:’liSi_update’}, {$set: {age:40}},{multi:true}) 將document數(shù)據(jù)中name是liSi_update 的數(shù)據(jù)的age修改為 40
注:如果有多條name是liSi的數(shù)據(jù)這些數(shù)據(jù)全部更新

db.worker.update({name:’liSi_update’},{$inc:{age:1}}) 將document數(shù)據(jù)中name是lliSi_update 的數(shù)據(jù)的age在原來(lái)的基礎(chǔ)上加1

2.save()方法通過(guò)傳入的文檔來(lái)替換已有文檔
語(yǔ)法
db.collection.save(
<document>,
{
writeConcern: <document>
}
參數(shù)說(shuō)明:
  document : 文檔數(shù)據(jù)藻茂。
  writeConcern  :可選,拋出異常的級(jí)別玫恳。
實(shí)例
db.person.save({_id:ObjectId(“562c9caf671c978b6596e825”),name:”xiaoHong”,age:10})

db.collection_name.save();

刪除文檔
db.collection_name.remove({})

MongoDB 刪除文檔
remove()方法是用來(lái)移除集合中的數(shù)據(jù)辨赐。
注:在執(zhí)行remove()函數(shù)前先執(zhí)行find()命令來(lái)判斷執(zhí)行的條件是否正確,這是一個(gè)比較好的習(xí)慣纽窟。
語(yǔ)法
db.collection.remove(
   <query>,
   <justOne>
)
如果你的 MongoDB 是 2.6 版本以后的肖油,語(yǔ)法格式如下:
db.collection.remove(
   <query>,
   {
     justOne: <boolean>,
     writeConcern: <document>
   }
)
參數(shù)說(shuō)明:
query :(可選)刪除的文檔的條件。
justOne : (可選)如果設(shè)為 true 或 1臂港,則只刪除一個(gè)文檔森枪。
writeConcern  :(可選)拋出異常的級(jí)別。
實(shí)例
db.worker.remove({name:’fJianZhou’}) 刪除worker集合里name是fJianZhou的所有Document數(shù)據(jù)

db.person.remove({name:”xiaoHong”},1)  刪除person集合里name是xiaoHong的第一條數(shù)據(jù)

查詢(xún)文檔
db.collection_name.find()

MongoDB 查詢(xún)文檔
1.find()方法
語(yǔ)法
db.collection_name.find()  collection_name 集合的名字
實(shí)例
db.worker.find()  查詢(xún)worker下所有的document數(shù)據(jù)

2.find()方法 查詢(xún)指定列
語(yǔ)法
db.collection_name.find({queryWhere},{key:1,key:1}) collection_name 集合的名字 key要顯示字段  1表示顯示  queryWhere參閱查詢(xún)條件操作符
實(shí)例
db.worker.find({},{age:1}) 查詢(xún)指定列 

3.pretty()方法以格式化的方式來(lái)顯示所有文檔审孽。
語(yǔ)法
db.collection_name.find().pretty()   collection_name 集合的名字
實(shí)例
 db.worker.find().pretty()

4.findOne()方法查詢(xún)匹配結(jié)果的第一條數(shù)據(jù)
語(yǔ)法
db.collection_name.findOne()  collection_name 集合的名字
實(shí)例

db.collection_name.find().pretty()
db.collection_name.findOne()

查詢(xún)條件操作符

查詢(xún)條件操作符
描述:條件操作符用于比較兩個(gè)表達(dá)式并從mongoDB集合中獲取數(shù)據(jù)县袱。

1.MongoDB (>) 大于操作符 - $gt
語(yǔ)法
db.collectionName.find({<key>:{$gt:<value>}}) collectionName集合名詞    key字段    value值
實(shí)例
db.worker.find({age:{$gt:30}}) 查詢(xún)age 大于 30的數(shù)據(jù)

2.MongoDB(>=)大于等于操作符 - $gte
語(yǔ)法
db.collectionName.find({<key>:{$gte:<value>}}) collectionName集合名詞    key字段    value值
實(shí)例
db.worker.find({age: {$gte: 30}}) 查詢(xún)age 3大于等于30 的數(shù)據(jù)

3.MongoDB (<) 小于操作符 - $lt
語(yǔ)法
db.collectionName.find( {<key>:{$lt:<value>}}) collectionName集合名詞    key字段    value值
實(shí)例
db.worker.find({age: {$lt: 30}}) 查詢(xún)age 小于30的數(shù)據(jù)

4.MongoDB (<=) 小于等于操作符 - $lte
語(yǔ)法
 db.collectionName.find({<key>:{$lte:<value>}}) collectionName集合名詞    key字段    value值
實(shí)例
db.worker.find({age: {$lte: 30}}) 查詢(xún)age 小于等于30的數(shù)據(jù)

5.MongoDB 使用 (>=) 和 (<=) 查詢(xún) - $gte 和 $lte
語(yǔ)法
 db.collectionName.find({<key>:{$gte:<value>},<key>:{$lte:<value>}}) collectionName集合名詞    key字段    value值
實(shí)例
db.worker.find({age: {$gte: 30, $lte: 50}}) 查詢(xún)age 大于等于 30 并且 age 小于等于 50  的數(shù)據(jù)

6.MongoDB 等于(==)
語(yǔ)法
 db.collectionName.find({<key>:<value>,<key>:<value>})   collectionName集合名詞    key字段    value值
實(shí)例
db.worker.find({"age": 30})`查詢(xún)age = 30的數(shù)據(jù)

7.MongoDB 使用 _id進(jìn)行查詢(xún)
語(yǔ)法
db.collectionName.find({"_id" : ObjectId("value")})  value _id的值
實(shí)例
db.worker.find({"_id" : ObjectId("562af23062d5a57609133974")}) 查詢(xún)_id是 562af23062d5a57609133974 數(shù)據(jù)

8.MongoDB 查詢(xún)某個(gè)結(jié)果集的數(shù)據(jù)的條數(shù)
語(yǔ)法
db.collectionName.find().count()   collectionName集合名稱(chēng)
實(shí)例
db.worker.find().count() 

9.MongoDB 查詢(xún)某個(gè)字段的值當(dāng)中是否包含另一個(gè)值
語(yǔ)法
db.collection.find({key:/value/})   collectionName集合名稱(chēng) key 字段  value值
實(shí)例
db.worker.find({name:/value/}) 查詢(xún)name里包含zhang的數(shù)據(jù)

10.MongoDB 查詢(xún)某個(gè)字段的值當(dāng)中是否以另一個(gè)值開(kāi)頭
語(yǔ)法
db.collection.find({key:/^value/})   collectionName集合名稱(chēng) key 字段  value值
實(shí)例
db.worker.find({name:/^zhang/})

db.collection_name.find({age: {$gt: 30}})
大于

db.collection_name.find({age: {$gte: 30}})
大于等于

db.collection_name.find({age: {$lt: 30}})
小于

db.collection_name.find({age: {$lte: 30}})
小于等于

db.collection_name.find({age: {$gte: 30, $lte: 40}})
大于等于并且小于等于

db.collection_name.find({age: 30})
等于

db.collection_name.find().count()
查詢(xún)某個(gè)結(jié)果集的條數(shù)

db.collection_name.find({name: /xiao/})
根據(jù)正則表達(dá)式進(jìn)行查找

查詢(xún)條件AND 和 OR

查詢(xún)條件and和or
1.MongoDB AND 條件
MongoDB 的 find() 方法可以傳入多個(gè)鍵(key),每個(gè)鍵(key)以逗號(hào)隔開(kāi)
語(yǔ)法
db.col.find({key1:value1, key2:value2}).pretty()  
實(shí)例
db.worker.find({name:’tangcaiye’,age:30}) 查詢(xún)name是tangcaiye并且age是30的數(shù)據(jù)

2.MongoDB OR 條件
MongoDB OR 條件語(yǔ)句使用了關(guān)鍵字 $or,語(yǔ)法格式如下:
語(yǔ)法
db.col.find(
   {
      $or: [
         {key1: value1}, {key2:value2}
      ]
   }
)
實(shí)例
db.worker.find({$or:[{age = 30},{age = 50}]}) 查詢(xún)age = 30 或者 age = 50  的數(shù)據(jù)

3.AND 和 OR 聯(lián)合使用
語(yǔ)法
db.col.find(
   {
     key1:value1, 
     key2:value2,
     $or: [
         {key1: value1}, 
         {key2:value2}
     ]
   }
)
實(shí)例
 查詢(xún) name是tangcaiye 并且 age是30 或者 age是 50 的數(shù)據(jù)
 db.worker.find({name:’tangcaiye’,$or:[{age:30},{age:50}]})

db.collectinon_name.find({name: “”, age: 20})
and的關(guān)系

db.collection_name.find({$or: [{age: 20}, {age: 30}]})
or的關(guān)系

limit和skip

MongoDB Limit與Skip方法
1.MongoDB Limit() 方法 讀取指定數(shù)量的數(shù)據(jù)記錄
語(yǔ)法
db.collectionName.find().limit(number)    collectionName集合    number讀取的條數(shù)
實(shí)例
db.worker.find().limit(3) 查詢(xún)前3條數(shù)據(jù)

2.MongoDB Skip() 方法 跳過(guò)指定數(shù)量的數(shù)據(jù)佑力,skip方法同樣接受一個(gè)數(shù)字參數(shù)作為跳過(guò)的記錄條數(shù)式散。
語(yǔ)法
db.collectionName.find().skip(number)    collectionName集合    number跳過(guò)的條數(shù)
實(shí)例
db.worker.find().skip(3) 查詢(xún)3條以后的數(shù)據(jù)

3.MongoDB Skip()方法和Limit()方法混合使用
注: 通常用這種方式來(lái)實(shí)現(xiàn)分頁(yè)功能
語(yǔ)法
db.collectionName.find().limit(number).skip(number)  
實(shí)例
db.worker.find().sort({age:-1}) 查詢(xún)?cè)?-6之間的數(shù)據(jù)
db.collection_name.find().limit(2)
只獲取兩條

db.collection_name.find().skip(1)
跳過(guò)1個(gè)

排序
排序
MongoDB sort()方法可以通過(guò)參數(shù)指定排序的字段,并使用 1 和 -1 來(lái)指定排序的方式打颤,其中 1 為升序排列暴拄,而-1是用于降序排列。
語(yǔ)法
db.collectionName.find().sort({KEY:1}) 或者 db.collectionName.find().sort({KEY:-1})  collectionName集合  key表示字段   
實(shí)例
db.worker.find().sort({age:1}) 查詢(xún)出并升序排序 {age:1}  age表示按那個(gè)字段排序 1表示升序

db.worker.find().sort({age:-1})  查詢(xún)出并降序排序  {age:-1} age表示按那個(gè)字段排序 -1表示降序

db.collection_name.find().sort({age: 1})
正序

db.collection_name.find().sort({age: -1})
倒敘

mongoose

Mongoose是mongoldb的一個(gè)對(duì)象模型工具

Mongoose是MongoDB的一個(gè)對(duì)象模型工具编饺,是基于node-mongoldb-native開(kāi)發(fā)的MongoDB nodes驅(qū)動(dòng)乖篷,可以在異步的
環(huán)境下執(zhí)行。同時(shí)它也是針對(duì)MongoDB操作的一個(gè)對(duì)象模型庫(kù)透且,封裝了MongoDB對(duì)文檔的的一些增刪改查等常用方法撕蔼,讓Node
JS操作Mongodb數(shù)據(jù)庫(kù)變得更加靈活簡(jiǎn)單。

安裝
npm install mongoose

使用

var mongoose = require(‘mongoose’);
var db = mongoose.connect(“mongodb://127.0.0.1:27017”);

綁定回調(diào)函數(shù)
db.connection.on(“err”, function (err) {});
db.connection.on(“open”, function () {});

數(shù)據(jù)操作

創(chuàng)建骨架模型Schema

3.Schema與Model
Schema : 一種以文件形式存儲(chǔ)的數(shù)據(jù)庫(kù)模型骨架,不具備數(shù)據(jù)庫(kù)的操作能力
Model : 由Schema發(fā)布生成的模型鲸沮,具有抽象屬性和行為的數(shù)據(jù)庫(kù)操作對(duì)
雖然模式(Schema)在MongoDB的存儲(chǔ)中并不是必須的琳骡,但是一般來(lái)說(shuō)為了文檔的整齊一致我們?cè)贛ongoose中還是會(huì)用到模式∷夏纾可以說(shuō)楣号,Mongoose中的一切都從定義模式開(kāi)
不像傳統(tǒng)的關(guān)系型數(shù)據(jù)庫(kù)一樣,比如mysql肾胯,連接好數(shù)據(jù)后直接有把sql語(yǔ)句丟到一個(gè)指定的方法中就執(zhí)行了竖席,這里會(huì)有Schema的抽象概念
Schema它類(lèi)似于關(guān)系數(shù)據(jù)庫(kù)的表結(jié)構(gòu),可以理解為數(shù)據(jù)庫(kù)模型骨架
Schema可以看作工廠中模具一樣敬肚,好比一個(gè)茶杯,喝水是茶杯最終的功能束析,茶杯本身就像是Model艳馒,那么茶杯的批量生產(chǎn)是需要靠工廠的模具成型的,這就像是Schema了
Schema不僅定義了文檔結(jié)構(gòu)和使用性能员寇,還可以有擴(kuò)展插件弄慰、實(shí)例方法、靜態(tài)方法蝶锋、復(fù)合索引陆爽、文檔生命周期鉤子
// 骨架模型
var Schema = mongoose.Schema;
var movieSchema = new Schema({
    title: String,
    price: Number
});
var  personSchema = new  Schema({
    name: {type: String, default: "李大澤"}, 
     age: {type: Number}}, {
    collection: "personhaah"
});

創(chuàng)建模型

// 模型
var Movie = mongoose.model(“movie”, movieSchema);

根據(jù)模型創(chuàng)建數(shù)據(jù)

// 創(chuàng)建數(shù)據(jù)
var movie = new Movie({
title: "黑衣人",
price: 68.5
});

保存數(shù)據(jù)

// 保存到數(shù)據(jù)庫(kù)movie.save(function (err) {
    if (err) {
        console.log(err);
    } else {
        console.log("保存成功");
    }});
Movie.create({
    title: "過(guò)年好",
    price: 28.5}, function (err) {
    if (err) {
        console.log(err);
    } else {
        console.log("哦哦哦");
    }});

查詢(xún)數(shù)據(jù)

    var query = {

        title: "過(guò)年好"

    };

    Movie.find(query, function (err, doc) {
    
    console.log(doc);

    });

修改數(shù)據(jù)

 var update = {
 
 $set: {
 
     price: 50
 
 }

 };

 Movie.update(query, update,
  function (err) {

      if (err) {

              console.log(err);
     } else {

             console.log("修改成功");
             }
     
});

// 請(qǐng)注意如果匹配到多條記錄会前,默認(rèn)只更新一條仆百,如果要更新匹配到的所有記錄的話需要加一個(gè)參數(shù) {multi:true}

     Movie.update(query, update, {
         multi: true
     }, function (err) {
         if(err) {
             console.log(err);
         } else {
             console.log("全部更新成功");
         }
     });

更多操作
屬性過(guò)濾

find(Conditions,field,callback);
field省略或?yàn)镹ull,則返回所有屬性查排。
//返回只包含name躯舔、age兩個(gè)鍵的所有記錄
Model.find({},{name:1, age:1, _id:0}驴剔,function(err,docs){ //docs 查詢(xún)結(jié)果集 })
說(shuō)明:我們只需要把顯示的屬性設(shè)置為大于零的數(shù)就可以,當(dāng)然1是最好理解的粥庄,_id是默認(rèn)返回丧失,如果不要顯示加上(“_id”:0),但是惜互,對(duì)其他不需要顯示的屬性且不是_id布讹,
如果設(shè)置為0的話將會(huì)拋異常或查詢(xún)無(wú)果训堆。
findOne(查詢(xún)單條)
與find相同描验,但只返回單個(gè)文檔,也就說(shuō)當(dāng)查詢(xún)到即一個(gè)符合條件的數(shù)據(jù)時(shí)蔫慧,將停止繼續(xù)查詢(xún)挠乳,并返回查詢(xún)結(jié)果。
1.單條數(shù)據(jù)

 findOne(Conditions,callback);
 TestModel.findOne({ age: 6}, function (err, doc){
    // 查詢(xún)符合age等于6的第一條數(shù)據(jù)
    // doc是查詢(xún)結(jié)果
 });

findOne方法,只返回第一個(gè)符合條件的文檔數(shù)據(jù)睡扬。
findById(按ID單條數(shù)據(jù))
與findOne相同盟蚣,但它只接收文檔的_id作為參數(shù),返回單個(gè)文檔卖怜。
1.按ID單條數(shù)據(jù) findById(_id, callback);

 PersonModel.findById(person._id, function (err, doc){
  //doc 查詢(xún)結(jié)果文檔
 }); 

//大于

 Model.find({“age”:{“$gt”:6}}, function (err,doc) {
     console.log(doc);
 });

//小于

 Model.find({“age”:{“$lt”:9}}, function (err,doc) {
     console.log(doc);
 });

//不等于

 Model.find({“age”:{“$ne”:8}}, function (err,doc) {
     console.log(doc);
 })

$or(或者)
$or操作符屎开,可以查詢(xún)多個(gè)鍵值的任意給定值,只要滿足其中一個(gè)就可返回马靠,用于存在多個(gè)條件判定的情況下使用奄抽,如下示例:

 Model.find({“$or”:[{“name”:”tangcaiye”},{“age”:6}]},function(error,docs){
   //查詢(xún)name為tangcaiye或age為6的全部文檔
 });

$exists(是否存在)
$exists操作符,可用于判斷某些關(guān)鍵字段是否存在來(lái)進(jìn)行條件查詢(xún)甩鳄。如下示例:

 Model.find({name: {$exists: true}},function(error,docs){
   //查詢(xún)所有存在name屬性的文檔
 });
> Model.find({email: {$exists: false}},function(error,docs){
   //查詢(xún)所有不存在email屬性的文檔
 });

簡(jiǎn)介
數(shù)據(jù)庫(kù)使用游標(biāo)返回find的執(zhí)行結(jié)果逞度。客戶(hù)端對(duì)游標(biāo)的實(shí)現(xiàn)通常能夠?qū)ψ罱K結(jié)果進(jìn)行有效的控制妙啃〉翟螅可以限制結(jié)果的數(shù)量,略過(guò)部分結(jié)果揖赴,根據(jù)任意鍵按任意順序的組合對(duì)結(jié)果進(jìn)行各種排序馆匿,或者是執(zhí)行其他操作。
最常用的查詢(xún)選項(xiàng)就是限制返回結(jié)果的數(shù)量(limit函數(shù))燥滑、忽略一點(diǎn)數(shù)量的結(jié)果(skip函數(shù))以及排序(sort函數(shù))渐北。所有這些選項(xiàng)一點(diǎn)要在查詢(xún)被發(fā)送到服務(wù)器之前指定。
limit函數(shù)的基本用法
在查詢(xún)操作中铭拧,有時(shí)數(shù)據(jù)量會(huì)很大赃蛛,這時(shí)我們就需要對(duì)返回結(jié)果的數(shù)量進(jìn)行限制,那么我們就可以使用limit函數(shù)羽历,通過(guò)它來(lái)限制結(jié)果數(shù)量焊虏。
1.限制數(shù)量:find(Conditions,fields,options,callback);

 Model.find({},null,{limit:20},function(err,docs){
     console.log(docs);
 });

如果匹配的結(jié)果不到20個(gè),則返回匹配數(shù)量的結(jié)果秕磷,也就是說(shuō)limit函數(shù)指定的是上限而非下限诵闭。
skip函數(shù)的基本用法
skip函數(shù)和limit類(lèi)似,都是對(duì)返回結(jié)果數(shù)量進(jìn)行操作澎嚣,不同的是skip函數(shù)的功能是略過(guò)指定數(shù)量的匹配結(jié)果疏尿,返回余下的查詢(xún)結(jié)果。如下示例:
1.跳過(guò)數(shù)量:find(Conditions,fields,options,callback);

 Model.find({},null,{skip:4},function(err,docs){
     console.log(docs);
 });

如果查詢(xún)結(jié)果數(shù)量中少于4個(gè)的話易桃,則不會(huì)返回任何結(jié)果褥琐。
sort函數(shù)的基本用法
sort函數(shù)可以將查詢(xún)結(jié)果數(shù)據(jù)進(jìn)行排序操作,該函數(shù)的參數(shù)是一個(gè)或多個(gè)鍵/值對(duì)晤郑,鍵代表要排序的鍵名敌呈,值代表排序的方向贸宏,1是升序,-1是降序磕洪。
1.結(jié)果排序:find(Conditions,fields,options,callback);

 Model.find({},null,{sort:{age:-1}},function(err,docs){
   //查詢(xún)所有數(shù)據(jù)吭练,并按照age降序順序返回?cái)?shù)據(jù)docs
 });

sort函數(shù)可根據(jù)用戶(hù)自定義條件有選擇性的來(lái)進(jìn)行排序顯示數(shù)據(jù)結(jié)果

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市析显,隨后出現(xiàn)的幾起案子鲫咽,更是在濱河造成了極大的恐慌,老刑警劉巖谷异,帶你破解...
    沈念sama閱讀 211,817評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件分尸,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡歹嘹,警方通過(guò)查閱死者的電腦和手機(jī)箩绍,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,329評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)荞下,“玉大人伶选,你說(shuō)我怎么就攤上這事〖饣瑁” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,354評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵构资,是天一觀的道長(zhǎng)抽诉。 經(jīng)常有香客問(wèn)我,道長(zhǎng)吐绵,這世上最難降的妖魔是什么迹淌? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,498評(píng)論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮己单,結(jié)果婚禮上唉窃,老公的妹妹穿的比我還像新娘。我一直安慰自己纹笼,他們只是感情好纹份,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,600評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著廷痘,像睡著了一般蔓涧。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上笋额,一...
    開(kāi)封第一講書(shū)人閱讀 49,829評(píng)論 1 290
  • 那天元暴,我揣著相機(jī)與錄音,去河邊找鬼兄猩。 笑死茉盏,一個(gè)胖子當(dāng)著我的面吹牛鉴未,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播鸠姨,決...
    沈念sama閱讀 38,979評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼铜秆,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了享怀?” 一聲冷哼從身側(cè)響起羽峰,我...
    開(kāi)封第一講書(shū)人閱讀 37,722評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎添瓷,沒(méi)想到半個(gè)月后梅屉,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,189評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡鳞贷,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,519評(píng)論 2 327
  • 正文 我和宋清朗相戀三年坯汤,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片搀愧。...
    茶點(diǎn)故事閱讀 38,654評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡惰聂,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出咱筛,到底是詐尸還是另有隱情搓幌,我是刑警寧澤,帶...
    沈念sama閱讀 34,329評(píng)論 4 330
  • 正文 年R本政府宣布迅箩,位于F島的核電站溉愁,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏饲趋。R本人自食惡果不足惜拐揭,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,940評(píng)論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望奕塑。 院中可真熱鬧堂污,春花似錦、人聲如沸龄砰。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,762評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)寝贡。三九已至扒披,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間圃泡,已是汗流浹背碟案。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,993評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留颇蜡,地道東北人价说。 一個(gè)月前我還...
    沈念sama閱讀 46,382評(píng)論 2 360
  • 正文 我出身青樓辆亏,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親鳖目。 傳聞我的和親對(duì)象是個(gè)殘疾皇子扮叨,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,543評(píng)論 2 349

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

  • 1.express node Web應(yīng)用框架,提供了很多Web應(yīng)用和HTTP工具 使用express可以快速搭建一...
    昵稱(chēng)不能太隨便閱讀 1,324評(píng)論 0 2
  • MongoDB是一個(gè)基于分布式文件存儲(chǔ)的數(shù)據(jù)庫(kù)领迈。由C++語(yǔ)言編寫(xiě)彻磁。旨在為WEB應(yīng)用提供可擴(kuò)展的高性能數(shù)據(jù)存儲(chǔ)解決方...
    入戲半分笑閱讀 375評(píng)論 0 2
  • MongoDB與關(guān)系型數(shù)據(jù)庫(kù)對(duì)比 MongoDB屬于文檔型的非關(guān)系型數(shù)據(jù)庫(kù),其他像Redis就屬于鍵值對(duì)型的非關(guān)系...
    少見(jiàn)多怪閱讀 1,750評(píng)論 0 4
  • 第一章 前言 1.1 知識(shí)體系分析 前端工程師:Web前端狸捅,也就是在Web應(yīng)用中用戶(hù)可以看得見(jiàn)碰得著的東西衷蜓。包括W...
    whitsats閱讀 866評(píng)論 0 3
  • 安裝 MongoDB Windowns、Ubuntu17.10 下安裝 MongoDB教程在此 MongoDB 幫...
    Kangvcar閱讀 2,091評(píng)論 0 13