Mongodb 數(shù)據(jù)類型及Mongoose常用CURD
前言
看完了Node.js實(shí)戰(zhàn),其中在數(shù)據(jù)存儲(chǔ)部分提到了Redis、Mongodb,我自己也根據(jù)書中的介紹寫了幾個(gè)簡(jiǎn)單的demo,在demo的過程首先遇到的問題就是數(shù)據(jù)類型和常見的CURD寫法。 mongodb的常見操作有兩種方式,一個(gè)是直接使用API,也就相當(dāng)于你在SQL Server客戶端中使用T-SQL編寫SQL語句來操作數(shù)據(jù)一樣,其次就是在程序中使用mongoose驅(qū)動(dòng)來操作數(shù)據(jù),相當(dāng)于我們?cè)诔绦蚶镉肁DO.NET或EF來操作數(shù)據(jù),如果你已經(jīng)寫了幾個(gè)調(diào)用API的demo,那么我建議再回過頭來看看mongoose的API,多看API,并且記住常見的幾個(gè)方法比如where,skip,sort等
按照以往我們編寫Web方式,我們會(huì)關(guān)注數(shù)據(jù)從客戶端(Views)如果到Controller層, 然后把數(shù)據(jù)如何從Controller層傳遞到Dao層以及這兩個(gè)層面?zhèn)鬟f數(shù)據(jù)時(shí)的一些技巧,那么在Node里這種思維也是適用的。
什么是MongoDB?
MongoDB 是一個(gè)開源的 NoSQL 數(shù)據(jù)庫,相比 MySQL 那樣的關(guān)系型數(shù)據(jù)庫,它更為輕巧、靈活,非常適合在數(shù)據(jù)規(guī)模很大、事務(wù)性不強(qiáng)的場(chǎng)合下使用。
Mongoose
Mongoose是封裝了MongoDB的操作的一個(gè)對(duì)象模型庫,為nodejs而生。就好像我們嫌原生javascript難寫,代碼量多,于是用jQuery庫一樣,因?yàn)镸ongoDB的操作接口復(fù)雜,不人性,所以有了Mongoose。這個(gè)庫完全是可選的。
Mongoose的使用非常簡(jiǎn)單,在App的package.js中的dependence中加入mongoose,然后 npm install 即可。
Mongodb數(shù)據(jù)類型
1、null。{"x":null}。
2、Boolean。{"x":true} 、{"x":false}。
3、數(shù)據(jù)類型。在Mongodb Shell中默認(rèn)使用64位浮點(diǎn)型數(shù)據(jù),如{"x":2.32}、{"x":2},如果要使用整數(shù)類型則用{"x":NumberInt(2)}、{"x":NumberLong(2)}。
4、字符串。Mongodb中字符串采用UTF-8編碼方式,{"x":"hello world"}。
5、日期類型。{"x":new Date()}。
6、正則表達(dá)式。 Mongodb中可使用和javascript相同的正則表達(dá)式 {"x":/itbilu/i}。
7、數(shù)據(jù)。Mongodb中數(shù)組的使用和javascript相同{"x":["hello","world"]}。
8、內(nèi)嵌文檔。{"x":{"y":"Hello"}}。
9、Id和ObjectId()。Mongodb每個(gè)文檔都會(huì)包含一個(gè)_id,如果你不指定時(shí)Mongodb會(huì)自動(dòng)生成一個(gè)ObjectId對(duì)象。
10、代碼。{"x":function aa(){}}。
11、二進(jìn)制。
常見CURD
var mongoose=require('mongoose'); var Schema=mongoose.Schema; //1、連接字符串 mongoose.connect('mongodb://localhost/test'); //2、定義你的數(shù)據(jù)模型(也就是我們?cè)陉P(guān)系數(shù)據(jù)庫中定義的Table) var TodoSchema=new Schema({ title:String, finished:{type:Boolean,default:false}, post_date:{type:Date,default:Date.now} }); //3、訪問todo對(duì)象模型 mongoose.model('Todo',TodoSchema); //添加 exports.add=function(title,callback){ var newTodo=new Todo(); newTodo.title=title; newTodo.save(function(err){ if(err){ console.log(err); callback(err); }else{ callback(null); } }); } //查找單獨(dú)的數(shù)據(jù) var findTodoById=exports.findTodoById=function(id,callback){ Todo.findOne({_id:id},function(err,doc){ //doc也就是根據(jù)id得到的記錄值 if(err){ callback(err,null); } callback(null,doc); }) } //刪除 exports.delete=function(id,callback){ exports.findTodoById(id,function(err,doc){ if(err){ callback(err); }else{ doc.remove(); callback(null); } }) } //編輯標(biāo)題 exports.editTitle=function(id,title,callback){ exports.findTodoById(id,function(err,doc){ if(err){ callback(err); }else{ doc.post_date=new Date(); doc.title=title; doc.save(function(err){ if(err){ callback(err); }else{ callback(null); } }) } }) } exports.allTodos=function(callback){ Todo.find({},callback); } //分頁查詢 exports.TodoPageList=function(pageIndex,pageSize,callback){ var m=Todo.find({}); //也有方法直接這樣寫: var m=this; var start=(pageIndex-1)*pageSize; m.skip(start); m.limit(pageSize); m.sort({'post_date','asc'}); //排序 //根據(jù)關(guān)鍵字查詢后分頁 //m.where('title','XXX'); //執(zhí)行分頁查詢 m.exec(function(err,rs){ //分頁后的結(jié)果 if(err){ callback(err); }else{ Todo.find(function(err,result){ /* 一般情況下的分頁你需要同時(shí)返回?cái)?shù)據(jù)庫記錄總數(shù)和分頁后的數(shù)據(jù),所以這里使用了Todo.find再查詢一次 */ callback({rows:rs,total:result.length}); }); } }) }
以上內(nèi)容是小編給大家介紹的Mongodb 數(shù)據(jù)類型及Mongoose常用CURD ,希望大家喜歡。
- MongoDB 常用的數(shù)據(jù)類型和基本操作
- Java將日期類型Date時(shí)間戳轉(zhuǎn)換為MongoDB的時(shí)間類型數(shù)據(jù)
- Mongodb 利用mongoshell進(jìn)行數(shù)據(jù)類型轉(zhuǎn)換的實(shí)現(xiàn)方法
- 基于MongoDB數(shù)據(jù)庫的數(shù)據(jù)類型和$type操作符詳解
- mongodb 數(shù)據(jù)類型(null/字符串/數(shù)字/日期/內(nèi)嵌文檔/數(shù)組等)
- MongoDB支持的java數(shù)據(jù)類型和測(cè)試?yán)?/a>
- MongoDB常用數(shù)據(jù)類型分享
相關(guān)文章
詳解MongoDB數(shù)據(jù)庫基礎(chǔ)操作及實(shí)例
這篇文章主要介紹了詳解MongoDB數(shù)據(jù)庫基礎(chǔ)操作及實(shí)例的相關(guān)資料,希望通過本文能幫助到大家,需要的朋友可以參考下2017-09-09Windows系統(tǒng)下安裝MongoDB并內(nèi)網(wǎng)穿透遠(yuǎn)程連接
這篇文章主要給大家介紹了關(guān)于Windows系統(tǒng)下安裝MongoDB并內(nèi)網(wǎng)穿透遠(yuǎn)程連接的相關(guān)資料,文中通過圖文將步驟介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MongoDB具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2023-03-03vs2019 下用 vb.net編寫窗體程序連接 mongodb4.2的方法
這篇文章主要介紹了vs2019 下用 vb.net編寫窗體程序連接 mongodb4.2,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08MongoDB的聚合框架Aggregation Framework入門學(xué)習(xí)教程
MongoDB中的聚合aggregate主要用于處理數(shù)據(jù)計(jì)算,這里我們就來詳細(xì)整理MongoDB的聚合框架Aggregation Framework入門學(xué)習(xí)教程,需要的朋友可以參考下2016-07-07分布式文檔存儲(chǔ)數(shù)據(jù)庫之MongoDB訪問控制的操作方法
這篇文章主要介紹了分布式文檔存儲(chǔ)數(shù)據(jù)庫之MongoDB訪問控制的操作方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11在Linux服務(wù)器中配置mongodb環(huán)境的步驟
這篇文章主要介紹了在Linux服務(wù)器中配置mongodb環(huán)境的步驟,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07MongoDB查詢之高級(jí)操作詳解(多條件查詢、正則匹配查詢等)
這篇文章主要給大家介紹了關(guān)于MongoDB查詢之高級(jí)操作(多條件查詢、正則匹配查詢等)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10Linux下MongoDB數(shù)據(jù)庫實(shí)現(xiàn)自動(dòng)備份詳解
這篇文章主要給大家介紹了在Linux系統(tǒng)下下MongoDB數(shù)據(jù)庫實(shí)現(xiàn)自動(dòng)備份的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編一起來學(xué)習(xí)學(xué)習(xí)吧。2017-06-06