Mongoose 在egg中的使用_MongoDB

來源:腳本之家  責任編輯:小易  

1、靜態方法中不能2113調用非靜態方法。5261 2、如果靜態方法中必須要4102調用非靜態方法,可以先new(實例1653),之后通過new實例的引用調用此類的方法。 3、如果一個類被實例化了,那么這個類中除了private的,都可以調用到www.anxorj.tw防采集請勿采集本網。

Mongoose是什么?

就類似connect是一樣的. 創建一知個執行連道 model.pre->schema.pre->schema.save model.pre 可以是具體業務邏輯的一些數據驗回證,或者原始數據轉換. schema.pre 跟業務無答關的數據操作

Mongoose是MongoDB的一個對象模型工具,封裝了許多MongoDB對文檔的的增刪改查等常用方法,讓NodeJS操作Mongodb數據庫變得更加靈活簡單。

我曾經翻譯過mongoose的文檔,并對里面的很多例子進行了實踐,雖然不多,一開始也有8.Middleware中間件 8.1 什么是中間件 中間件是一種控制函數,類似插件,能控制流程中的init、validate、save.

在egg項目中如何使用?

var mongoose=require(\"mongoose\");mongoose.connect(\"mongodb:/localhost/mydb01\");var User=mongoose.model(\"User\",{ id:Double,/報錯指向這里,說 Double is not defined name:{ type:String,

1、安裝

與使用連接字符串的方法比較相似,如下為mongoose連接localhost上的words數據庫 var mongoose=require(‘mongoose’);mongoose.connect('mongodb:/localhost/words');該鏈接可用mongoose模塊的

npm i egg-mongoose --save

2、配置

在根目錄下的/config/plugin.js中配置插件

exports.mongoose = { enable: true, package: 'egg-mongoose',};

3、連接數據庫

在根目錄下的/config/config.default.js增加配置,其中url為我們的數據庫地址,可通過環境變量來區分開發環境還是生產環境,并且確定是否使用用戶名密碼的數據庫

const prod = process.env.npm_config_server_prod;

mongoose: { client: { url: prod ? 'mongodb:eggadmin:[email protected]:27017/DbName' : 'mongodb://127.0.0.1:27017/DbName', options: { useUnifiedTopology: true, }, }, },

4、配置與使用

(1)數據表配置

在app目錄下新建model文件夾,在model文件夾下新建JS文件作為數據表的配置內容,下面以書籍表的配置為例

'use strict';/** * @description: Mongoose book Schema, */module.exports = app => { const mongoose = app.mongoose; const Schema = mongoose.Schema; const BookSchema = new Schema({ desc: { type: String }, /* 書籍描述 */ name: { type: String }, /* 書籍名稱 */ press: { type: String }, /* 出版社 */ author: { type: String }, /* 作者 */ image: { type: Array }, /* 書籍圖片列表*/ price: { type: String }, /* 價格 */ book_type: { /* 書籍分類id */ type: Schema.Types.ObjectId, ref: 'BookClassify', }, user: { /* 書籍發布者id */ type: Schema.Types.ObjectId, ref: 'User', }, create_time: { type: String }, /* 創建時間 */ status: { type: String }, /* 狀態,1:待購買,2:已購買*/ look: { type: Number } /* 瀏覽數量 */ }); return mongoose.model('Book', BookSchema);};

可以看到我們可以通過Schema來定義表結構,可以指定字段的類型及關聯,設置完字段后就可以生成model了,這里算是非常簡單的配置,更多配置方法可參考文檔

(2)、使用mongoose方法

配置完數據表結構后,我們就可以再service層中調用mongoose的方法對文檔進行增刪查改了,已書籍列表的處理邏輯為例子

async findbookList(data) { const { type, page, pageSize, desc, status, userId } = data; const searchVal = {} if (type) { searchVal.book_type = mongoose.Types.ObjectId(type) } if (status) { searchVal.status = status } if (userId) { searchVal.user = mongoose.Types.ObjectId(userId) } const search_term = { $or: [ { desc: { $regex: desc ? desc : '', $options: '$i' } }, { name: { $regex: desc ? desc : '', $options: '$i' } }, { author: { $regex: desc ? desc : '', $options: '$i' } }, { press: { $regex: desc ? desc : '', $options: '$i' } }, ], }; const totalNum = await this.ctx.model.Book.find(searchVal).and(search_term).countDocuments(); const result = await this.ctx.model.Book.find(searchVal) .populate({ path: 'user', select: { name: 1, image: 1 } }) .populate({ path: 'book_type' }) .and(search_term) .sort({ create_time: -1 }) .skip((parseInt(page) - 1) * parseInt(pageSize)) .limit(parseInt(pageSize)); return result ? { bean: { records: result, current: page, size: result.length, total: totalNum, }, ...app.config.msg.GET_SUCCESS } : app.config.msg.GET_ERR; }

可以看到,通過this.ctx.model.Book就可以獲取到Book的model并且可以調用mongoose需要的方法,例如populate、find、and、sort、skip、limit 等等。

5、egg-Mongoose常用的方法

增加數據

this.ctx.model.Book.create(data,callback);

其中data為json數據結構,callback為操作后的回調函數

查詢數據

獲取所有數據,返回是一個數組

this.ctx.model.Book.find()

獲取一個數據,返回是一個對象

this.ctx.model.Book.findOne()

條件查詢

this.ctx.model.Article.find(conditions,callback);

其中conditions為查詢的條件,callback為回調函數

conditions有一下幾種情況:

具體數據:

this.ctx.model.Book.find({_id:5c4a19fb87ba4002a47ac4d, name: "射雕英雄傳" }, callback);

條件查詢:

"$lt" 小于"$lte" 小于等于"$gt" 大于"$gte" 大于等于"$ne" 不等于// 查詢價格大于100小于200的書籍數組this.ctx.model.Book.find({ "price": { $get:100 , $lte:200 });

或查詢 OR

"$in" 一個鍵對應多個值"$nin" 同上取反, 一個鍵不對應指定值"$or" 多個條件匹配, 可以嵌套 $in 使用"$not" 同上取反, 查詢與特定模式不匹配的文檔this.ctx.model.Book.find({"name":{ $in: ["射雕","倚天"]} );

刪除數據

this.ctx.model.Book.remove(conditions,callback);

更新數據

this.ctx.model.Book.update(conditions, update, callback)

conditions為條件,update是更新的值對象

排序

this.ctx.model.Book.sort({ create_time: -1 });

其中-1表示降序返回。 1表示升序返回

限制數量

this.ctx.model.Book.limit(number);

number表示限制的個數

跳過文檔返回

this.ctx.model.Book.skip(number);

number表示跳過的個數,skip經常搭配limit實現分頁的功能

條件數組and

在find后面可使用and對查詢結果進行進一步條件篩選,相當于并且的意思。

const search_term = { $or: [ { desc: { $regex: desc ? desc : '', $options: '$i' } }, { name: { $regex: desc ? desc : '', $options: '$i' } }, { author: { $regex: desc ? desc : '', $options: '$i' } }, { press: { $regex: desc ? desc : '', $options: '$i' } }, ], }; this.ctx.model.Book.find().and(search_term)

關聯查詢populate

// 在model中配置字段時候指定關聯的表名,就可以通過populate來進行表的關聯查詢user: { /* 書籍發布者id */ type: Schema.Types.ObjectId, ref: 'User', }, this.ctx.model.Book.find() .populate({ path: 'user', select: { name: 1, image: 1 } })

聚合管道Aggregate

this.ctx.model.Template.aggregate([ { $match: { name } }, { $sort: { create_time: -1 } }, { $group: { _id: '$name', user_id: { $first: '$modifier' } } }, ]);

Mongoose聚合管道aggregate常用的操作有$project 、$match 、$group、$sort、$limit、$skip、$lookup 表關聯

批量操作bulkWrite

const template_list = await ctx.model.Template.aggregate([ { $sort: { create_time: -1 } }, { $group: { _id: '$name', template_id: { $first: '$_id' }, label: { $first: '$label' } } }, ]); const update_value = []; template_list.forEach(item => { if (!item.label) { update_value.push({ updateOne: { filter: { _id: item.template_id }, update: { label: '' }, }, }); } }); await ctx.model.Template.bulkWrite(update_value);

可以進行一系列批量增加、刪除、更新等操作。

mongoose還有非常多的方法可以提供給我的靈活使用,我們在使用的時候可以結合業務邏輯選擇合適的方法來提高我們操作數據庫的效率。在我們使用它之前可以認真的閱讀官方文檔

對于靜態方法:我想查找所有的故事書(而且以后經常查找),但不想每次都用原生方法 Book.find({category:story}),寫起來好麻煩,于是我就可以定義一個靜態方法:以后就可以這么查 Book.isStory()就ok了對于實例方法:比如我想根據具體的一本書,比如《不平凡的世界》查找和和它類似的書,則定義實例方法 doc.isSimilar(xxx)。實例方法嘛,調用者是具體的實例,此處肯定不能用靜態方法吧。以前僅供參考,希望有幫助,如果沒幫助,可以看看java相關的,因為那里面也有靜態方法實例方法,可以借鑒下思想內容來自www.anxorj.tw請勿采集。


  • 本文相關:
  • egg.js的基本使用和調用數據庫的方法示例
  • 關于自定義egg.js的請求級別日志詳解
  • koa+egg.js集成kafka消息隊列的示例
  • mongoose更新對象的兩種方法示例比較
  • 關于在mongoose中填充外鍵的方法詳解
  • 利用mongoose讓json數據直接插入或更新到mongodb
  • 詳解nodejs基于mongoose模塊的增刪改查的操作
  • 關于mongoose連接mongodb重復訪問報錯的解決辦法
  • mongodb中數據的替換方法實現類replace()函數功能詳解
  • mongodb存儲時間時差問題的解決方法
  • 十個提高mongodb安全性的配置技巧
  • mongodb中強大的統計框架aggregation使用實例解析
  • centos 6.4創建mongodb副本集
  • mongodb開啟權限認證的方法步驟詳解
  • mongodb 快速入門
  • mongodb與sql關系型數據比較
  • windows7下使用mongodb實現倉儲設計
  • mongodb實現問卷/考試設計功能
  • mongoose中實例方法和靜態方法分別在哪些業務上使用
  • mongoose中實例方法和靜態方法分別在哪些業務上使用
  • 如何使用mongoose的api連接到db中一個已有的集合?
  • Mongoose怎么用一個 條件 在多個字段查詢
  • 怎么理解 Mongoose 的 pre 中間件,還有 path
  • 怎么理解 Mongoose 的 pre 中間件,還有 path
  • mongoose中model怎么定義數據類型
  • 如何使用mongoose連接數據庫中已經存在的一個集合
  • 如何用mongoose直接查詢數據中的數量
  • 網站首頁網頁制作腳本下載服務器操作系統網站運營平面設計媒體動畫電腦基礎硬件教程網絡安全mssqlmysqlmariadboracledb2mssql2008mssql2005sqlitepostgresqlmongodbredisaccess數據庫文摘數據庫其它首頁mongodbegg.js的基本使用和調用數據庫的方法示例關于自定義egg.js的請求級別日志詳解koa+egg.js集成kafka消息隊列的示例mongoose更新對象的兩種方法示例比較關于在mongoose中填充外鍵的方法詳解利用mongoose讓json數據直接插入或更新到mongodb詳解nodejs基于mongoose模塊的增刪改查的操作關于mongoose連接mongodb重復訪問報錯的解決辦法mongodb中數據的替換方法實現類replace()函數功能詳解mongodb存儲時間時差問題的解決方法十個提高mongodb安全性的配置技巧mongodb中強大的統計框架aggregation使用實例解析centos 6.4創建mongodb副本集mongodb開啟權限認證的方法步驟詳解mongodb 快速入門mongodb與sql關系型數據比較windows7下使用mongodb實現倉儲設計mongodb實現問卷/考試設計功能mongodb常用操作命令大全mongodb各種查詢操作詳解mongodb數據庫插入、更新和刪除操mongodb 數據庫操作--備份 還原 mongodb插入數據的3種方法mongodb中使用distinct去重的簡單mongodb整庫備份與還原以及單個cmongodb查詢操作限制返回字段的方mongodb 實現遠程連接淺談mysql和mariadb區別(mariadbubuntu下安裝mongodb 3.4的詳細過程mongodb 復制(副本集)學習筆記mongodb eval 執行服務器端腳本mongodb中mapreduce實現數據聚合方法詳解mongodb日常使用的技巧與注意事項匯總mongodb安裝與配置筆記mongodb入門教程之c#驅動操作實例mongodb 多重數組查詢(angularjs綁定顯示mongodb中聚合函數java處理示例詳解利用mongodb查詢某坐標是否在規定多邊形區
    免責聲明 - 關于我們 - 聯系我們 - 廣告聯系 - 友情鏈接 - 幫助中心 - 頻道導航
    Copyright © 2017 www.anxorj.tw All Rights Reserved
    陕西快乐10分下载