前言 看完了Node.js實戰,其中在數據存儲部分提到了Redis、Mongodb,我自己也根據書中的介紹寫了幾個簡單的demo,在demo的過程首先遇到的問題就是數據類型和常見的CURD寫法。 mongodb的常見操作有兩種方式,一個是直接使用API,也就相當於你在SQL Server客戶端中.....
前言
看完了Node.js實戰,其中在數據存儲部分提到了Redis、Mongodb,我自己也根據書中的介紹寫了幾個簡單的demo,在demo的過程首先遇到的問題就是數據類型和常見的CURD寫法。 mongodb的常見操作有兩種方式,一個是直接使用API,也就相當於你在SQL Server客戶端中使用T-SQL編寫SQL語句來操作數據一樣,其次就是在程式中使用mongoose驅動來操作數據,相當於我們在程式里用ADO.NET或EF來操作數據,如果你已經寫了幾個調用API的demo,那麼我建議再回過頭來看看mongoose的API,多看API,並且記住常見的幾個方法比如where,skip,sort等
按照以往我們編寫Web方式,我們會關註數據從客戶端(Views)如果到Controller層, 然後把數據如何從Controller層傳遞到Dao層以及這兩個層面傳遞數據時的一些技巧,那麼在Node里這種思維也是適用的。
Mongodb數據類型
1、null。{"x":null}。
2、Boolean。{"x":true} 、{"x":false}。
3、數據類型。在Mongodb Shell中預設使用64位浮點型數據,如{"x":2.32}、{"x":2},如果要使用整數類型則用{"x":NumberInt(2)}、{"x":NumberLong(2)}。
4、字元串。Mongodb中字元串採用UTF-8編碼方式,{"x":"hello world"}。
5、日期類型。{"x":new Date()}。
6、正則表達式。 Mongodb中可使用和javascript相同的正則表達式 {"x":/itbilu/i}。
7、數據。Mongodb中數組的使用和javascript相同{"x":["hello","world"]}。
8、內嵌文檔。{"x":{"y":"Hello"}}。
9、Id和ObjectId()。Mongodb每個文檔都會包含一個_id,如果你不指定時Mongodb會自動生成一個ObjectId對象。
10、代碼。{"x":function aa(){}}。
11、二進位。
常見CURD
var mongoose=require('mongoose'); var Schema=mongoose.Schema; //1、連接字元串 mongoose.connect('mongodb://localhost/test'); //2、定義你的數據模型(也就是我們在關係資料庫中定義的Table) var TodoSchema=new Schema({ title:String, finished:{type:Boolean,default:false}, post_date:{type:Date,default:Date.now} }); //3、訪問todo對象模型 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); } }); } //查找單獨的數據 var findTodoById=exports.findTodoById=function(id,callback){ Todo.findOne({_id:id},function(err,doc){ //doc也就是根據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); } }) } //編輯標題 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'}); //排序 //根據關鍵字查詢後分頁 //m.where('title','XXX'); //執行分頁查詢 m.exec(function(err,rs){ //分頁後的結果 if(err){ callback(err); }else{ Todo.find(function(err,result){ /* 一般情況下的分頁你需要同時返回資料庫記錄總數和分頁後的數據,所以這裡使用了Todo.find再查詢一次 */ callback({rows:rs,total:result.length}); }); } }) }
參考地址
http://www.nodeclass.com/api/mongoose.html#query-js
http://itbilu.com/database/mongo/E1MxCQfS.html#objectId
http://www.cnblogs.com/flyoung2008/archive/2012/07/22/2603791.html