亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

node使用Mongoose類庫實現(xiàn)簡單的增刪改查

 更新時間:2018年11月08日 09:34:40   作者:涂根華  
Mongoose是在nodejs環(huán)境中對MongoDB數(shù)據(jù)庫操作的封裝,這篇文章主要介紹了node使用Mongoose類庫實現(xiàn)簡單的增刪改查,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

Mongoose是在nodejs環(huán)境中對MongoDB數(shù)據(jù)庫操作的封裝,一種對象模型工具,可以將數(shù)據(jù)庫中的數(shù)據(jù)轉(zhuǎn)換為javascript對象供我們使用。

Mongoose安裝

npm install mongoose

安裝成功后,我們就可以使用 require('mongoose')來使用了;

下面是鏈接本地數(shù)據(jù)庫 mongoosedb,代碼如下:

var mongoose = require('mongoose');
var DB_URL = 'mongodb://localhost:27017/dataDb';

/* 鏈接 */
mongoose.connect(DB_URL);

/* 鏈接成功 */
mongoose.connection.on('connected', function() {
 console.log('Mongoose connection open to ' + DB_URL);
});

// 鏈接異常
mongoose.connection.on('error', function(err) {
 console.log('Mongoose connection error:' + err);
});

// 鏈接斷開

mongoose.connection.on('disconnected', function() {
 console.log('Mongoose connection disconnected');
});

如下圖所示

從如上代碼,監(jiān)聽了幾個事件,并且執(zhí)行觸發(fā)了connected事件,這表示連接成功。

2. Schema介紹

它是一種以文件形式存儲的數(shù)據(jù)庫模型骨架,不具備對數(shù)據(jù)庫操作的能力,僅僅只是數(shù)據(jù)庫在程序片段中的一種表現(xiàn),可以理解為表結(jié)構(gòu)。

那么如何去定義一個Schema呢?請看如下代碼:

var mongoose = require('mongoose');
var TestSchema = new mongoose.Schema({
 name: { type: String }, // 屬性name,類型為String
 age: { type: Number, default: 30 }, // 屬性age,類型為Number,默認(rèn)值為30
 time: { type: Date, default: '當(dāng)前時間' }
});

如上在我們的TestSchema中每個key在我們的文件將被轉(zhuǎn)換為相關(guān)的SchemaType定義的一個屬性。允許使用的SchemaTypes有如下類型:

  • String
  • Number
  • Date
  • Buffer
  • Boolean
  • Mixed
  • ObjectId
  • Array

如果我們在如上編寫完成后,我們需要添加額外的鍵的話,我們可以使用Schema中的add方法.

3. 創(chuàng)建一個模型

我們上面定義了Schema,我們需要將我們的TestSchema轉(zhuǎn)成我們可以使用的模型,模型具有對數(shù)據(jù)庫操作的能力。
我們可以通過 mongoose.model(modelName, schema);

先來結(jié)合schema和創(chuàng)建一個模型來簡單的看一個demo,如下代碼:

var mongoose = require('mongoose');
// schema定義
var TestSchema = new mongoose.Schema({
 name: { type: String },
 age: { type: String },
 sex: { type: String }
});

// 創(chuàng)建model
var TestModel = mongoose.model('test1', TestSchema);

// 初始化數(shù)據(jù) 
var TestInt = new TestModel({
 name: 'kongzhi',
 age: '30',
 sex: 'girl'
});

console.log(TestInt.name); // kongzhi
console.log(TestInt.age); // 30
console.log(TestInt.sex); // girl

下面我們來簡單的使用上面定義的內(nèi)容,來做個簡單的數(shù)據(jù)庫增刪改查的操作。

1. 在項目中的根目錄下新建一個db.js, 代碼如下:

var mongoose = require('mongoose');
var DB_URL = 'mongodb://localhost:27017/dataDb';

/* 鏈接 */
mongoose.connect(DB_URL);

/* 鏈接成功 */
mongoose.connection.on('connected', function() {
 console.log('Mongoose connection open to ' + DB_URL);
});

// 鏈接異常
mongoose.connection.on('error', function(err) {
 console.log('Mongoose connection error:' + err);
});

// 鏈接斷開

mongoose.connection.on('disconnected', function() {
 console.log('Mongoose connection disconnected');
});

module.exports = mongoose;

2. 下面我們新建一個user的Schema,命名為user.js, 它有如下屬性,如下代碼:

/*
 定義一個user的Schema
*/
var mongoose = require('./db.js');
var Schema = mongoose.Schema;

var UserSchema = new Schema({
 username: { type: String }, // 用戶名
 password: { type: String }, // 密碼
 age: { type: Number }, // 年齡
});

/* model 是由schema生成的模型,具有對數(shù)據(jù)庫操作的能力 */

module.exports = mongoose.model('User', UserSchema);

3. 數(shù)據(jù)庫操作,我們新建一個文件叫 app.js

3.1 插入數(shù)據(jù)(Model.save([fn])),代碼如下:

var User = require('./user.js');
// 插入數(shù)據(jù)

var user = new User({
 username: 'kongzhi0707',
 password: '123456',
 age: 30
});

user.save(function(err, res) {
 if (err) {
  console.log(err);
 } else {
  console.log(res);
 }
});

然后在命令行中運行app.js ,可以看到如下:

然后我們再到本地數(shù)據(jù)庫中查看數(shù)據(jù),可以看到新增一條數(shù)據(jù),如下圖所示

從數(shù)據(jù)庫中可以看到插入數(shù)據(jù)成功了;

3.2 更新數(shù)據(jù)(Model.update(conditions, doc, [options], [callback]))

conditions: 更新的條件,該值是一個對象。
doc: 需要更新的內(nèi)容,該值也是一個對象。
options: 可選參數(shù),它有如下屬性:
safe :(布爾型)安全模式(默認(rèn)為架構(gòu)中設(shè)置的值(true))
upsert :(boolean)如果不匹配,是否創(chuàng)建文檔(false)
multi :(boolean)是否應(yīng)該更新多個文檔(false)
runValidators:如果為true,則在此命令上運行更新驗證程序。更新驗證器根據(jù)模型的模式驗證更新操作。
strict:(布爾)覆蓋strict此更新的選項
overwrite: (布爾)禁用只更新模式,允許您覆蓋文檔(false)
callback: 回調(diào)函數(shù)

如下代碼執(zhí)行更新:

var User = require('./user.js');

// 更新數(shù)據(jù) 

function update() {
 // 更新數(shù)據(jù)的條件查詢
 var wherestr = {'username': 'kongzhi0707'};

 // 執(zhí)行更新數(shù)據(jù)
 var updatestr = {'password': 'abcdef'};

 User.update(wherestr, updatestr, function(err, res) {
  if (err) {
   console.log(err);
  } else {
   console.log(res);
  }
 });
}
// 調(diào)用更新函數(shù)
update();

運行app.js 后,如下圖所示:

繼續(xù)查看數(shù)據(jù)庫,可以看到password字段被更新了,如下圖所示:

3.3 findByIdAndUpdate(id, [update], [options], [callback]);

根據(jù)id進(jìn)行更新;此id就是數(shù)據(jù)庫中自動生成的id;如下代碼,

var User = require('./user.js');

// 更新數(shù)據(jù) 

function update() {
 // 更新數(shù)據(jù)的條件查詢
 var id = '5b3a4941ca11752732fee772';

 // 執(zhí)行更新數(shù)據(jù)
 var updatestr = {'password': 'vvvvv'};

 User.findByIdAndUpdate(id, updatestr, function(err, res) {
  if (err) {
   console.log(err);
  } else {
   console.log(res);
  }
 });
}
// 調(diào)用更新函數(shù)
update();

如下圖數(shù)據(jù)庫顯示如下:

3.4 刪除 Model.remove(conditions, [callback])

代碼如下:

var User = require('./user.js');

function del() {
 // 刪除數(shù)據(jù)的條件
 var wherestr = {'username': 'kongzhi0707'};

 User.remove(wherestr, function(err, res) {
  if (err) {
   console.log(err);
  } else {
   console.log(res);
  }
 });
}
// 調(diào)用函數(shù)
del();

到數(shù)據(jù)庫中查看數(shù)據(jù),可以看到?jīng)]有這條數(shù)據(jù)了;

3.5 條件查詢 Model.find(conditions, [fields], [options], [callback]);

如下代碼所示:

var User = require('./user.js');
function find() {
 // 刪除數(shù)據(jù)的條件
 var wherestr = {'userName': '龍恩0707'};

 User.find(wherestr, function(err, res) {
  if (err) {
   console.log(err);
  } else {
   console.log(res);
  }
 });
}
// 調(diào)用函數(shù)
find();

執(zhí)行后,如下所示:

3.6 數(shù)量查詢 Model.count(conditions, [callback])

var User = require('./user.js');

function getCountByConditions() {

 User.count({}, function(err, res) {
  if (err) {
   console.log(err);
  } else {
   console.log(res); // 會輸出數(shù)據(jù)庫數(shù)據(jù)的數(shù)量
  }
 });
}
// 調(diào)用函數(shù)
getCountByConditions();

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Express之托管靜態(tài)文件的方法

    Express之托管靜態(tài)文件的方法

    本篇文章主要介紹了Express之托管靜態(tài)文件的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • node實現(xiàn)socket鏈接與GPRS進(jìn)行通信的方法

    node實現(xiàn)socket鏈接與GPRS進(jìn)行通信的方法

    這篇文章主要介紹了node實現(xiàn)socket鏈接與GPRS進(jìn)行通信的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • Windows上node.js的多版本管理工具用法實例分析

    Windows上node.js的多版本管理工具用法實例分析

    這篇文章主要介紹了Windows上node.js的多版本管理工具用法,結(jié)合實例形式分析了Windows平臺上node.js多版本管理工具nvm-windows的相關(guān)使用技巧,需要的朋友可以參考下
    2019-11-11
  • express的中間件basicAuth詳解

    express的中間件basicAuth詳解

    這篇文章主要介紹了node.js中express的中間件basicAuth的使用方法,需要的朋友可以參考下
    2014-12-12
  • node.js中的fs.readlink方法使用說明

    node.js中的fs.readlink方法使用說明

    這篇文章主要介紹了node.js中的fs.readlink方法使用說明,本文介紹了fs.readlink方法說明、語法、接收參數(shù)、使用實例和實現(xiàn)源碼,需要的朋友可以參考下
    2014-12-12
  • 30分鐘用Node.js構(gòu)建一個API服務(wù)器的步驟詳解

    30分鐘用Node.js構(gòu)建一個API服務(wù)器的步驟詳解

    這篇文章主要介紹了30分鐘用Node.js構(gòu)建一個API服務(wù)器的步驟詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-05-05
  • node.js中path路徑模塊的使用方法實例分析

    node.js中path路徑模塊的使用方法實例分析

    這篇文章主要介紹了node.js中path路徑模塊的使用方法,結(jié)合實例形式分析了node.js path路徑模塊的基本功能、原理、使用方法及操作注意事項,需要的朋友可以參考下
    2020-02-02
  • 一次NodeJS內(nèi)存泄漏排查的實戰(zhàn)記錄

    一次NodeJS內(nèi)存泄漏排查的實戰(zhàn)記錄

    這篇文章主要給大家介紹了一次NodeJS內(nèi)存泄漏排查的實戰(zhàn)記錄,文中給出了詳細(xì)的排查過程以及內(nèi)存泄漏的解決方法,大家可以學(xué)習(xí)一下以備不時之需,需要的朋友可以參考下
    2022-03-03
  • nodejs不用electron實現(xiàn)打開文件資源管理器并選擇文件

    nodejs不用electron實現(xiàn)打開文件資源管理器并選擇文件

    最近在開發(fā)一些小腳本,用 nodejs 實現(xiàn),其中很多功能需要選擇一個/多個文件,或者是選擇一個文件夾,這種情況下網(wǎng)上給出的解決方案都是 electron,但是我一個小腳本用 electron 屬實有點夸張了,后來轉(zhuǎn)念一想可以通過 powershell 來實現(xiàn)類似的功能,需要的朋友可以參考下
    2024-01-01
  • Node.js一行代碼實現(xiàn)靜態(tài)文件服務(wù)器的方法步驟

    Node.js一行代碼實現(xiàn)靜態(tài)文件服務(wù)器的方法步驟

    這篇文章主要介紹了Node.js一行代碼實現(xiàn)靜態(tài)文件服務(wù)器的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05

最新評論