程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MongoDB數據庫 >> MongoDB綜合知識 >> Mongodb 數據類型及Mongoose常用CURD

Mongodb 數據類型及Mongoose常用CURD

編輯:MongoDB綜合知識

前言

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

   MongoDB 是一個開源的 NoSQL 數據庫,相比 MySQL 那樣的關系型數據庫,它更為輕巧、靈活,非常適合在數據規模很大、事務性不強的場合下使用。 

Mongoose

Mongoose是封裝了MongoDB的操作的一個對象模型庫,為nodejs而生。就好像我們嫌原生javascript難寫,代碼量多,於是用jQuery庫一樣,因為MongoDB的操作接口復雜,不人性,所以有了Mongoose。這個庫完全是可選的。
   Mongoose的使用非常簡單,在App的package.js中的dependence中加入mongoose,然後 npm install 即可。

 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});
      });
    }
  })
}

以上內容是小編給大家介紹的Mongodb 數據類型及Mongoose常用CURD ,希望大家喜歡。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved