MongoDB基礎(chǔ)知識全網(wǎng)最全2

四、語法

1.向集合中插入20000個條數(shù)據(jù)

# 方法一:    耗時:7.2s    效率太差
for(var i=1; i<20000; i++){
      db.collection.insert({num:i});
} 

# 方法二:    耗時0.4s   效率很好
var arr = [];
for(var i=1; i<20000; i++){
      arr.push({num:i});
} 
db.collection.insert(arr);

2.查詢collection中num大于500的所有數(shù)據(jù)

db.collection.find({num:{$gt:500}});

3.查詢collection中num大于40,小于50的所有數(shù)據(jù)

db.collection.find({num:{$gt:40,$lt:50}});
# 注意:開發(fā)中絕對不能使用無條件地查詢

4.查詢collection中前10條數(shù)據(jù)

db.collection.find().limit(10);         
# limit()限制獲取數(shù)據(jù)數(shù)量的上限 

5.查詢collection中第11到20條數(shù)據(jù)

db.collection.find().skip(10).limit(10);  
# skip()跳過指定數(shù)量的數(shù)據(jù)
# 注意:skip()與limit()位置可以顛倒,MongoDB會自動調(diào)整它們的順序

6.查詢工資(sal)小于1000或大于2500的員工

db.collection.find({$or:[{sal:{$lt:1000}},{sal:{$gt:2500}}]})

7.所有工資低于1000的員工加400元的工資

db.collection.updateMany({sal:{$lt:1000}},{$inc:{sal:400}})

8.查詢文檔時,讓查詢結(jié)果按sal進行排序

注: 默認情況根據(jù)_id進行排序

db.collection.find({}).sort({sal:1})          #1 代表升序, -1代表降序
# 注意:如果對象中有兩個字段,那么先根據(jù)第一個字段進行排序裤唠。
# 如果遇到第一個字段相同的數(shù)據(jù),再對這些數(shù)據(jù)進行第二個字段的排序

五鹃操、知識點

1.文檔之間的關(guān)系:

  • 一對一 (one to one) 夫妻
  • 一對多/多對一 (one to many)/(many to one) 父母-孩子
  • 多對多 (many to many)

六甘磨、mongoose

1.Node.js中使用mongoose

1.下載安裝mongoose

npm install --save mongoose

2.在項目中引入mongoose

var mongoose = require("mongoose");

3.連接MongoDB

mongoose.connect("mongodb://數(shù)據(jù)庫的ip地址:端口號/數(shù)據(jù)庫名",{useNewUrlParser:true})
   注意:如果端口號是默認端口號(27017),則可以省略端口號
   — 監(jiān)聽MongoDB數(shù)據(jù)庫的連接狀態(tài)
   — 在mongoose對象中,有一個屬性叫做connection,該對象表示的就是數(shù)據(jù)庫連接
       通過監(jiān)視該對象的狀態(tài),可以來監(jiān)聽數(shù)據(jù)庫的連接與斷開

4.斷開MongoDB數(shù)據(jù)庫連接

注: 一般不需要調(diào)用
注: MongoDB數(shù)據(jù)庫,一般情況下,只連接一次,連接一次以后,除非項目停止服務(wù)器關(guān)閉,否則連接一般不會斷開

mongoose.disconnect()
// 數(shù)據(jù)庫連接成功的事件
mongoose.connection.once("open",function())
// 數(shù)據(jù)庫斷開的事件
mongoose.connection.once("close",function())

2.mongoose之Model

設(shè):

var StuModel = mongoose.model("student",stuSchema);

注意:
1.中括號表示可選,沒有括號表示必填
2.Model和數(shù)據(jù)庫中的集合一一對應(yīng)

Model.find([conditions],[projection],[options],[callback])
// conditions: 查詢條件 
// projection: 投影,需要獲取到的字段
// options: 查詢選項(skip limit)    //第三個參數(shù){skip:3,limit:1}
// callback: 回調(diào)函數(shù)
  • 1.StuModel.find({},{name:1,_id:0 },function(err,docs){});
    返回的是一個數(shù)組.docs為查詢返回的數(shù)據(jù)
  • 2.StuModel.find({},"name -_id",function(err,docs){});
    效果與1相同
  • 3.StuModel.findById("id",function(err){})
    返回的是一個對象
  • 4.StuModel.update(conditions,doc, [options], [callback])
  • 5.StuModel.updateMany(conditions,doc, [options], [callback])
  • 6.StuModel.updateOne(conditions,doc, [options], [callback])
  • 7.StuModel.remove(conditions, [callback])
  • 8.StuModel.deleteOne(conditions, [callback])
  • 9.StuModel.deleteMany(conditions, [callback])
  • 10.StuModel.count(): 統(tǒng)計文檔的數(shù)量

3.mongoose之Document

注意:Document和集合中的文檔一一對應(yīng),是Model的一個實例

1.創(chuàng)建一個Document對象(Model實例)

var stu = new StuModel({
     name: "孫悟空",
     age: 19,
     gender: "male",
     address: "花果山"
})

2.保存Document對象

Stu.save(function(err){});

3.修改Document對象

(1).doc.age = 18;
    doc.save();
(2).doc.update({$set:{age:28}},function(err){})
(3).doc.set("name","孫悟空");

4.刪除Document對象

doc.remove(function (err) {})

5.獲取文檔中指定的屬性值

(1).var demo = doc.get(“name”);
(2).var demo = doc.name;

6.將Document對象轉(zhuǎn)換為JSON數(shù)據(jù)

doc.toJSON();  

7.將Document對象轉(zhuǎn)換為object數(shù)據(jù)

doc.toObject();  
//注意:轉(zhuǎn)換為普通的js對象以后,所有的Document對象的方法或?qū)傩远紱]有用啦

文集推薦:

Java基礎(chǔ)方法集1
Python基礎(chǔ)知識完整版
Spring Boot學習筆記
Linux指令進階
Java高并發(fā)編程
SpringMVC基礎(chǔ)知識進階
Mysql基礎(chǔ)知識完整版
健康管理系統(tǒng)學習花絮(學習記錄)
Node.js基礎(chǔ)知識(隨手筆記)
MongoDB基礎(chǔ)知識
Dubbo學習筆記
Vue學習筆記(隨手筆記)

聲明:發(fā)表此文是出于傳遞更多信息之目的。若有來源標注錯誤或侵犯了您的合法權(quán)益铣墨,請作者持權(quán)屬證明與本我們(QQ:981086665;郵箱:981086665@qq.com)聯(lián)系聯(lián)系,我們將及時更正金刁、刪除,謝謝议薪。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末尤蛮,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子斯议,更是在濱河造成了極大的恐慌产捞,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,383評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件哼御,死亡現(xiàn)場離奇詭異坯临,居然都是意外死亡,警方通過查閱死者的電腦和手機恋昼,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,522評論 3 385
  • 文/潘曉璐 我一進店門看靠,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人液肌,你說我怎么就攤上這事挟炬。” “怎么了嗦哆?”我有些...
    開封第一講書人閱讀 157,852評論 0 348
  • 文/不壞的土叔 我叫張陵谤祖,是天一觀的道長。 經(jīng)常有香客問我老速,道長粥喜,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,621評論 1 284
  • 正文 為了忘掉前任橘券,我火速辦了婚禮额湘,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘约郁。我一直安慰自己缩挑,他們只是感情好,可當我...
    茶點故事閱讀 65,741評論 6 386
  • 文/花漫 我一把揭開白布鬓梅。 她就那樣靜靜地躺著供置,像睡著了一般。 火紅的嫁衣襯著肌膚如雪绽快。 梳的紋絲不亂的頭發(fā)上芥丧,一...
    開封第一講書人閱讀 49,929評論 1 290
  • 那天紧阔,我揣著相機與錄音,去河邊找鬼续担。 笑死擅耽,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的物遇。 我是一名探鬼主播乖仇,決...
    沈念sama閱讀 39,076評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼询兴!你這毒婦竟也來了乃沙?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,803評論 0 268
  • 序言:老撾萬榮一對情侶失蹤诗舰,失蹤者是張志新(化名)和其女友劉穎警儒,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體眶根,經(jīng)...
    沈念sama閱讀 44,265評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡蜀铲,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,582評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了属百。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片记劝。...
    茶點故事閱讀 38,716評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖诸老,靈堂內(nèi)的尸體忽然破棺而出隆夯,到底是詐尸還是另有隱情,我是刑警寧澤别伏,帶...
    沈念sama閱讀 34,395評論 4 333
  • 正文 年R本政府宣布蹄衷,位于F島的核電站,受9級特大地震影響厘肮,放射性物質(zhì)發(fā)生泄漏愧口。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 40,039評論 3 316
  • 文/蒙蒙 一类茂、第九天 我趴在偏房一處隱蔽的房頂上張望耍属。 院中可真熱鬧,春花似錦巩检、人聲如沸厚骗。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,798評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽领舰。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間冲秽,已是汗流浹背舍咖。 一陣腳步聲響...
    開封第一講書人閱讀 32,027評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留锉桑,地道東北人排霉。 一個月前我還...
    沈念sama閱讀 46,488評論 2 361
  • 正文 我出身青樓,卻偏偏與公主長得像民轴,于是被迫代替她去往敵國和親攻柠。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,612評論 2 350

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