Mongodb 數據類型及Mongoose常用CURD

jopen 8年前發布 | 10K 次閱讀 MongoDB NoSQL數據庫 mongoose

前言

看完了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

來自: http://www.cnblogs.com/sword-successful/p/5098327.html

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!