欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mongodb 數(shù)據(jù)類型及Mongoose常用CURD

 更新時間:2016年01月04日 13:36:52   作者:garfieldzf  
MongoDB 是一個開源的 NoSQL 數(shù)據(jù)庫,相比 MySQL 那樣的關(guān)系型數(shù)據(jù)庫,它更為輕巧、靈活,非常適合在數(shù)據(jù)規(guī)模很大、事務(wù)性不強(qiáng)的場合下使用,本文給大家介紹Mongodb 數(shù)據(jù)類型及Mongoose常用CURD,感興趣的朋友一起學(xué)習(xí)吧

前言

      看完了Node.js實戰(zhàn),其中在數(shù)據(jù)存儲部分提到了Redis、Mongodb,我自己也根據(jù)書中的介紹寫了幾個簡單的demo,在demo的過程首先遇到的問題就是數(shù)據(jù)類型和常見的CURD寫法。 mongodb的常見操作有兩種方式,一個是直接使用API,也就相當(dāng)于你在SQL Server客戶端中使用T-SQL編寫SQL語句來操作數(shù)據(jù)一樣,其次就是在程序中使用mongoose驅(qū)動來操作數(shù)據(jù),相當(dāng)于我們在程序里用ADO.NET或EF來操作數(shù)據(jù),如果你已經(jīng)寫了幾個調(diào)用API的demo,那么我建議再回過頭來看看mongoose的API,多看API,并且記住常見的幾個方法比如where,skip,sort等

     按照以往我們編寫Web方式,我們會關(guān)注數(shù)據(jù)從客戶端(Views)如果到Controller層, 然后把數(shù)據(jù)如何從Controller層傳遞到Dao層以及這兩個層面?zhèn)鬟f數(shù)據(jù)時的一些技巧,那么在Node里這種思維也是適用的。

什么是MongoDB?

   MongoDB 是一個開源的 NoSQL 數(shù)據(jù)庫,相比 MySQL 那樣的關(guān)系型數(shù)據(jù)庫,它更為輕巧、靈活,非常適合在數(shù)據(jù)規(guī)模很大、事務(wù)性不強(qiáng)的場合下使用。 

Mongoose

Mongoose是封裝了MongoDB的操作的一個對象模型庫,為nodejs而生。就好像我們嫌原生javascript難寫,代碼量多,于是用jQuery庫一樣,因為MongoDB的操作接口復(fù)雜,不人性,所以有了Mongoose。這個庫完全是可選的。
   Mongoose的使用非常簡單,在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位浮點型數(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每個文檔都會包含一個_id,如果你不指定時Mongodb會自動生成一個ObjectId對象。

    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ù)模型(也就是我們在關(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對象模型
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);
    }
  });
}
//查找單獨的數(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ù)據(jù)庫記錄總數(shù)和分頁后的數(shù)據(jù),所以這里使用了Todo.find再查詢一次
        */
        callback({rows:rs,total:result.length});
      });
    }
  })
}

以上內(nèi)容是小編給大家介紹的Mongodb 數(shù)據(jù)類型及Mongoose常用CURD ,希望大家喜歡。

相關(guān)文章

  • 詳解MongoDB數(shù)據(jù)庫基礎(chǔ)操作及實例

    詳解MongoDB數(shù)據(jù)庫基礎(chǔ)操作及實例

    這篇文章主要介紹了詳解MongoDB數(shù)據(jù)庫基礎(chǔ)操作及實例的相關(guān)資料,希望通過本文能幫助到大家,需要的朋友可以參考下
    2017-09-09
  • Windows系統(tǒng)下安裝MongoDB并內(nèi)網(wǎng)穿透遠(yuǎn)程連接

    Windows系統(tǒng)下安裝MongoDB并內(nèi)網(wǎng)穿透遠(yuǎn)程連接

    這篇文章主要給大家介紹了關(guān)于Windows系統(tǒng)下安裝MongoDB并內(nèi)網(wǎng)穿透遠(yuǎn)程連接的相關(guān)資料,文中通過圖文將步驟介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用MongoDB具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2023-03-03
  • vs2019 下用 vb.net編寫窗體程序連接 mongodb4.2的方法

    vs2019 下用 vb.net編寫窗體程序連接 mongodb4.2的方法

    這篇文章主要介紹了vs2019 下用 vb.net編寫窗體程序連接 mongodb4.2,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-08-08
  • MongoDB的聚合框架Aggregation Framework入門學(xué)習(xí)教程

    MongoDB的聚合框架Aggregation Framework入門學(xué)習(xí)教程

    MongoDB中的聚合aggregate主要用于處理數(shù)據(jù)計算,這里我們就來詳細(xì)整理MongoDB的聚合框架Aggregation Framework入門學(xué)習(xí)教程,需要的朋友可以參考下
    2016-07-07
  • 淺談MongoDB內(nèi)部的存儲原理

    淺談MongoDB內(nèi)部的存儲原理

    這篇文章主要介紹了淺談MongoDB內(nèi)部的存儲原理,MongoDB是一個面向文檔的數(shù)據(jù)庫系統(tǒng)。使用C++編寫,不支持SQL,但有自己功能強(qiáng)大的查詢語法,需要的朋友可以參考下
    2023-07-07
  • 分布式文檔存儲數(shù)據(jù)庫之MongoDB訪問控制的操作方法

    分布式文檔存儲數(shù)據(jù)庫之MongoDB訪問控制的操作方法

    這篇文章主要介紹了分布式文檔存儲數(shù)據(jù)庫之MongoDB訪問控制的操作方法,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • MongoDB中唯一索引(Unique)的那些事

    MongoDB中唯一索引(Unique)的那些事

    這篇文章主要給大家介紹了關(guān)于MongoDB中唯一索引(Unique)的那些事,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-01-01
  • 在Linux服務(wù)器中配置mongodb環(huán)境的步驟

    在Linux服務(wù)器中配置mongodb環(huán)境的步驟

    這篇文章主要介紹了在Linux服務(wù)器中配置mongodb環(huán)境的步驟,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • MongoDB查詢之高級操作詳解(多條件查詢、正則匹配查詢等)

    MongoDB查詢之高級操作詳解(多條件查詢、正則匹配查詢等)

    這篇文章主要給大家介紹了關(guān)于MongoDB查詢之高級操作(多條件查詢、正則匹配查詢等)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • Linux下MongoDB數(shù)據(jù)庫實現(xiàn)自動備份詳解

    Linux下MongoDB數(shù)據(jù)庫實現(xiàn)自動備份詳解

    這篇文章主要給大家介紹了在Linux系統(tǒng)下下MongoDB數(shù)據(jù)庫實現(xiàn)自動備份的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面跟著小編一起來學(xué)習(xí)學(xué)習(xí)吧。
    2017-06-06

最新評論