婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Mongoose 在egg中的使用詳解

Mongoose 在egg中的使用詳解

熱門標簽:呼和浩特外呼系統原理是什么 青白江400企業電話申請 crm外呼系統聯系方式 智能外呼系統官網 長沙電銷外呼防封卡是什么 小裙科技電銷機器人怎樣 河南電話外呼系統招商 外呼線路資源屬于電信業務嗎 內蒙古營銷智能外呼系統哪個好

Mongoose是什么?

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

在egg項目中如何使用?

1、安裝

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

總結

到此這篇關于Mongoose 在egg中的使用詳解的文章就介紹到這了,更多相關egg中使用Mongoose內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • egg.js的基本使用和調用數據庫的方法示例
  • 關于自定義Egg.js的請求級別日志詳解
  • KOA+egg.js集成kafka消息隊列的示例
  • mongoose更新對象的兩種方法示例比較
  • 關于在mongoose中填充外鍵的方法詳解
  • 利用Mongoose讓JSON數據直接插入或更新到MongoDB
  • 詳解Nodejs基于mongoose模塊的增刪改查的操作
  • 關于mongoose連接mongodb重復訪問報錯的解決辦法

標簽:安順 楚雄 菏澤 呼倫貝爾 白山 黃石 池州 舟山

巨人網絡通訊聲明:本文標題《Mongoose 在egg中的使用詳解》,本文關鍵詞  Mongoose,在,egg,中的,使用,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Mongoose 在egg中的使用詳解》相關的同類信息!
  • 本頁收集關于Mongoose 在egg中的使用詳解的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产精品一区二区在线观看不卡 | 日韩激情视频网站| 国产美女精品在线| 日韩精品一区二区三区在线观看| 亚洲第一综合色| 欧美视频日韩视频在线观看| 亚洲激情网站免费观看| 日本丶国产丶欧美色综合| 亚洲一区二区三区中文字幕在线| 色哟哟国产精品免费观看| 一区二区欧美精品| 欧美日韩精品久久久| 一区二区三区电影在线播| 91免费精品国自产拍在线不卡| 亚洲精选视频免费看| 99久久亚洲一区二区三区青草| 中文字幕一区在线观看视频| 色av成人天堂桃色av| 亚洲线精品一区二区三区| 日韩精品一区二区在线| 国产福利一区二区三区| 国产亚洲欧美色| 国产麻豆精品95视频| 中文乱码免费一区二区| 99热在这里有精品免费| 视频一区视频二区中文字幕| 精品88久久久久88久久久| 97aⅴ精品视频一二三区| 亚洲欧美日韩电影| 欧美日韩国产首页在线观看| 国产丶欧美丶日本不卡视频| 亚洲人成在线播放网站岛国| 欧美一区二视频| 成人免费高清在线| 日欧美一区二区| 国产精品网友自拍| 69堂国产成人免费视频| 成人av在线观| 久久97超碰色| 成人少妇影院yyyy| 午夜久久久久久久久| 中文字幕精品在线不卡| 欧美一区二区三区在线视频| 99久久久无码国产精品| 麻豆一区二区三| 国产精品理论在线观看| 欧美日韩电影一区| gogogo免费视频观看亚洲一| 黄色成人免费在线| 亚洲444eee在线观看| 国产精品蜜臀av| 欧美大片日本大片免费观看| 欧美性猛交一区二区三区精品| 国产白丝精品91爽爽久久| 日本美女视频一区二区| 亚洲视频在线观看三级| 国产欧美在线观看一区| 91.麻豆视频| 91美女视频网站| 成人h精品动漫一区二区三区| 久久精品国产成人一区二区三区| 在线播放中文一区| 久久精品欧美日韩| 亚洲一级在线观看| 日本美女一区二区三区| 国产伦精品一区二区三区免费 | 欧美r级在线观看| 国产精品不卡一区| 美女mm1313爽爽久久久蜜臀| 91视频xxxx| 久久久综合九色合综国产精品| 一区二区三区高清| www.激情成人| 日韩欧美黄色影院| 欧美喷潮久久久xxxxx| 中文字幕av一区二区三区免费看| 偷拍日韩校园综合在线| 国产成人av在线影院| 欧美老女人第四色| 亚洲青青青在线视频| 韩国视频一区二区| 欧美久久免费观看| 国产精品福利一区二区三区| 久久99国产乱子伦精品免费| 在线综合亚洲欧美在线视频| 一区二区三区在线观看欧美| 国产麻豆一精品一av一免费| 日韩视频在线永久播放| 亚洲国产欧美日韩另类综合| eeuss鲁片一区二区三区| 久久久久久麻豆| 美女www一区二区| 欧美喷潮久久久xxxxx| 亚洲欧美另类久久久精品2019| 国产精品88av| 精品欧美一区二区在线观看| 亚洲午夜精品在线| 欧美视频一区二区三区四区| 亚洲精品自拍动漫在线| 成人免费在线视频| 成人av在线网| 国产日韩成人精品| 国产高清不卡一区二区| 国产精品久久久久7777按摩| 国产成人av一区二区三区在线| 国产区在线观看成人精品 | 亚洲精品一区二区三区在线观看| 日日摸夜夜添夜夜添国产精品| 国产丝袜在线精品| 国产91精品一区二区| 中文av一区二区| 一本一道久久a久久精品综合蜜臀| 亚洲三级理论片| 色综合天天性综合| 一区二区在线观看视频| 欧美影院一区二区| 亚洲激情图片qvod| 欧美性生活影院| 青青草国产精品97视觉盛宴| 日韩色在线观看| 久久国产综合精品| 中文字幕欧美三区| 99精品视频在线免费观看| 亚洲欧美一区二区不卡| 一本色道久久综合亚洲aⅴ蜜桃 | 这里只有精品免费| 久久99久久久久| 国产欧美视频在线观看| 成人高清免费在线播放| 国产精品不卡视频| 欧洲亚洲国产日韩| 另类成人小视频在线| 国产精品色婷婷久久58| 色天使色偷偷av一区二区| 免费不卡在线视频| 日本一区二区三区四区| 在线观看视频一区二区 | 成人教育av在线| 亚洲在线观看免费| 精品88久久久久88久久久| 色哟哟一区二区| 国产伦精品一区二区三区免费| 午夜久久久久久电影| 中文av一区二区| 日韩女优毛片在线| 色婷婷综合久久久| 极品少妇xxxx精品少妇偷拍| 亚洲最新视频在线播放| 精品国产伦一区二区三区观看方式 | 久久精品视频一区二区| 亚洲自拍偷拍网站| 欧美日韩一区二区三区四区| 国产91高潮流白浆在线麻豆| 狂野欧美性猛交blacked| 亚洲主播在线播放| 日本最新不卡在线| 亚洲美女屁股眼交| 亚洲国产一区二区视频| 精品国产一区二区亚洲人成毛片| 成人永久免费视频| 蜜臀精品久久久久久蜜臀| 日韩美一区二区三区| 青青草一区二区三区| 亚洲精品国产高清久久伦理二区| 这里只有精品视频在线观看| 亚洲三级在线免费| 成人精品免费视频| 日本一区二区三区视频视频| 亚洲黄色性网站| 91国模大尺度私拍在线视频| 久久久影院官网| 国产精品激情偷乱一区二区∴| 日韩欧美亚洲国产精品字幕久久久| 日韩一区二区在线观看| 国产精品网站在线播放| 在线免费观看一区| 国产精品福利一区| 欧美精品一区二区久久婷婷| 99这里都是精品| 欧美日韩亚洲国产综合| av一本久道久久综合久久鬼色| eeuss鲁片一区二区三区在线观看| 国产一区二区伦理| 欧美日韩美少妇| 亚洲免费电影在线| 黄色小说综合网站| 国产精品夜夜嗨| 国产精品综合在线视频| 国产精品久久久久国产精品日日| 久久色.com| 日韩精品专区在线影院重磅| 丝袜亚洲另类欧美| 欧美一区二视频| 99综合影院在线| 26uuu色噜噜精品一区二区| 日韩欧美一卡二卡| 久久综合久久99| 欧美撒尿777hd撒尿| 成人理论电影网| 中文字幕高清一区|