亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MongoDB > 正文

Mongoose 在egg中的使用詳解

2020-10-29 18:40:27
字體:
來源:轉載
供稿:網友

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內容請搜索武林網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持武林網!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
992tv成人免费视频| 欧美夫妻性生活视频| 欧美亚洲成人xxx| 国产精品av免费在线观看| 久久久精品中文字幕| 最近2019年好看中文字幕视频| 97国产精品人人爽人人做| 日韩欧美黄色动漫| 日本一区二区三区在线播放| 国产精品久久久久久久久免费| 国产成人一区二区三区电影| 国产精品h在线观看| www.亚洲天堂| 欧美成aaa人片在线观看蜜臀| 亚洲天堂av高清| 亚洲精品欧美日韩专区| 51视频国产精品一区二区| 国产精品高潮在线| 国内精品模特av私拍在线观看| 国产精品欧美在线| 久久久久久久电影一区| 亚洲免费视频一区二区| 欧美在线观看日本一区| 国产精品一区二区久久精品| 亚洲人成在线免费观看| 国产精品99久久久久久白浆小说| 国产精品一区二区久久久| 精品国产精品自拍| 色yeye香蕉凹凸一区二区av| 91夜夜揉人人捏人人添红杏| 中文字幕日韩欧美在线视频| 欧美综合在线第二页| 精品视频—区二区三区免费| 一区二区三区视频免费| 成人黄色中文字幕| 狠狠躁天天躁日日躁欧美| 日韩av在线看| 国产精品网红福利| 国产精品入口夜色视频大尺度| 久久精品国产久精国产思思| 国产精品1区2区在线观看| 久久久久成人精品| 亚洲精品视频在线观看视频| 色播久久人人爽人人爽人人片视av| 狠狠躁夜夜躁人人爽超碰91| 亚洲一区二区三区视频| 法国裸体一区二区| 日韩av男人的天堂| 国产精品男女猛烈高潮激情| 亚洲性生活视频在线观看| 久久视频中文字幕| 一区二区三区四区在线观看视频| 中文字幕精品av| 久久人人爽人人爽人人片亚洲| 亚洲欧美综合区自拍另类| 福利视频一区二区| 国产精品黄色av| 国产欧美日韩丝袜精品一区| 精品亚洲一区二区三区在线观看| 一区二区日韩精品| 福利一区视频在线观看| 国产在线精品播放| 欧美激情精品久久久久| 狠狠躁天天躁日日躁欧美| 91精品国产亚洲| 精品国产一区二区三区久久| 日韩性生活视频| 久久亚洲国产精品成人av秋霞| 中文国产成人精品久久一| 91国内产香蕉| 久久久亚洲精品视频| 欧美成人在线免费视频| 亚洲精品美女视频| 亚洲国产成人av在线| 亚洲国产天堂久久综合网| 亚洲一区二区少妇| 最近中文字幕日韩精品| 91久久精品美女高潮| 久久精品视频va| 国产欧美一区二区三区在线| 久久亚洲精品毛片| 国产福利成人在线| 欧美日韩性生活视频| 国产精品久久久久久久久借妻| 91在线视频免费| 国产精品福利在线| 久久五月情影视| 亚洲人成绝费网站色www| 久久久av亚洲男天堂| 国产精品视频男人的天堂| 日韩电影免费在线观看| 亚洲成人1234| 精品国产一区二区三区久久狼5月| 日韩中文字幕网站| 国产精品视频免费观看www| 亚洲黄在线观看| 7777免费精品视频| 亚洲欧美一区二区三区四区| 中文字幕亚洲无线码a| 日韩女在线观看| 亚洲精品欧美一区二区三区| 韩日精品中文字幕| 亚洲激情自拍图| 久久91精品国产| 成人福利网站在线观看11| 日韩在线视频观看正片免费网站| 成人国产精品久久久久久亚洲| 国产成人亚洲综合| 国色天香2019中文字幕在线观看| 亚洲精品99久久久久中文字幕| 日韩视频免费在线观看| 久久久久999| 久久人人爽人人爽人人片亚洲| 日韩美女视频中文字幕| 尤物yw午夜国产精品视频| 欧美午夜激情在线| 久久69精品久久久久久国产越南| 国产男女猛烈无遮挡91| 日韩激情av在线播放| 在线成人激情黄色| 亚洲老板91色精品久久| 日本免费一区二区三区视频观看| 国产精品久久久久久搜索| 不卡av在线网站| 久久精品国产亚洲精品2020| 国产精品一区二区3区| 奇米四色中文综合久久| 中文字幕久久久av一区| 91精品在线影院| 欧美乱大交xxxxx另类电影| 亚洲激情国产精品| 成年人精品视频| 成人动漫网站在线观看| 成人精品一区二区三区电影黑人| 国产+人+亚洲| 国内精品视频一区| 狠狠爱在线视频一区| 亚洲精品综合精品自拍| 少妇高潮 亚洲精品| 国产精品一区二区av影院萌芽| 国产亚洲一级高清| 97碰在线观看| 在线免费观看羞羞视频一区二区| 最近2019免费中文字幕视频三| 欧美日韩视频免费播放| 国产精品三级美女白浆呻吟| 久久人人爽人人爽人人片亚洲| 久久久亚洲国产天美传媒修理工| 亚洲综合一区二区不卡| 最近更新的2019中文字幕| 欧美成人免费网| 精品亚洲一区二区三区| 亚洲第一网站免费视频| 成人免费视频xnxx.com| 国产97色在线|日韩| 亚洲成人黄色在线| 日韩欧美在线看| 中文字幕亚洲综合| 亚洲一区中文字幕| 日韩av最新在线| 国产婷婷色综合av蜜臀av| 亚洲欧美国产精品专区久久| 欧美日本国产在线| 欧美多人乱p欧美4p久久|