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

主頁(yè) > 知識(shí)庫(kù) > Mongoose 在egg中的使用詳解

Mongoose 在egg中的使用詳解

熱門標(biāo)簽:呼和浩特外呼系統(tǒng)原理是什么 青白江400企業(yè)電話申請(qǐng) crm外呼系統(tǒng)聯(lián)系方式 智能外呼系統(tǒng)官網(wǎng) 長(zhǎng)沙電銷外呼防封卡是什么 小裙科技電銷機(jī)器人怎樣 河南電話外呼系統(tǒng)招商 外呼線路資源屬于電信業(yè)務(wù)嗎 內(nèi)蒙古營(yíng)銷智能外呼系統(tǒng)哪個(gè)好

Mongoose是什么?

Mongoose是MongoDB的一個(gè)對(duì)象模型工具,封裝了許多MongoDB對(duì)文檔的的增刪改查等常用方法,讓NodeJS操作Mongodb數(shù)據(jù)庫(kù)變得更加靈活簡(jiǎn)單。

在egg項(xiàng)目中如何使用?

1、安裝

npm i egg-mongoose --save

2、配置

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

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

3、連接數(shù)據(jù)庫(kù)

在根目錄下的/config/config.default.js增加配置,其中url為我們的數(shù)據(jù)庫(kù)地址,可通過(guò)環(huán)境變量來(lái)區(qū)分開(kāi)發(fā)環(huán)境還是生產(chǎn)環(huán)境,并且確定是否使用用戶名密碼的數(shù)據(jù)庫(kù)
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)數(shù)據(jù)表配置

在app目錄下新建model文件夾,在model文件夾下新建JS文件作為數(shù)據(jù)表的配置內(nèi)容,下面以書(shū)籍表的配置為例

'use strict';

/**
 * @description: Mongoose book Schema,
 */

module.exports = app => {
 const mongoose = app.mongoose;
 const Schema = mongoose.Schema;
 const BookSchema = new Schema({
 desc: { type: String }, /* 書(shū)籍描述 */
 name: { type: String }, /* 書(shū)籍名稱 */
 press: { type: String }, /* 出版社 */
 author: { type: String }, /* 作者 */
 image: { type: Array }, /* 書(shū)籍圖片列表*/
 price: { type: String }, /* 價(jià)格 */
 book_type: { /* 書(shū)籍分類id */
 type: Schema.Types.ObjectId,
 ref: 'BookClassify',
 },
 user: { /* 書(shū)籍發(fā)布者id */
 type: Schema.Types.ObjectId,
 ref: 'User',
 },
 create_time: { type: String }, /* 創(chuàng)建時(shí)間 */
 status: { type: String }, /* 狀態(tài),1:待購(gòu)買,2:已購(gòu)買*/
 look: { type: Number } /* 瀏覽數(shù)量 */
 });
 return mongoose.model('Book', BookSchema);
};

可以看到我們可以通過(guò)Schema來(lái)定義表結(jié)構(gòu),可以指定字段的類型及關(guān)聯(lián),設(shè)置完字段后就可以生成model了,這里算是非常簡(jiǎn)單的配置,更多配置方法可參考文檔

(2)、使用mongoose方法

配置完數(shù)據(jù)表結(jié)構(gòu)后,我們就可以再service層中調(diào)用mongoose的方法對(duì)文檔進(jìn)行增刪查改了,已書(shū)籍列表的處理邏輯為例子

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;
 }

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

5、egg-Mongoose常用的方法

增加數(shù)據(jù)

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

其中data為json數(shù)據(jù)結(jié)構(gòu),callback為操作后的回調(diào)函數(shù)

查詢數(shù)據(jù)

獲取所有數(shù)據(jù),返回是一個(gè)數(shù)組

this.ctx.model.Book.find()

獲取一個(gè)數(shù)據(jù),返回是一個(gè)對(duì)象

this.ctx.model.Book.findOne()

條件查詢

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

其中conditions為查詢的條件,callback為回調(diào)函數(shù)
conditions有一下幾種情況:

具體數(shù)據(jù):

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

條件查詢:

"$lt" 小于
"$lte" 小于等于
"$gt" 大于
"$gte" 大于等于
"$ne" 不等于
// 查詢價(jià)格大于100小于200的書(shū)籍?dāng)?shù)組
this.ctx.model.Book.find({ "price": { $get:100 , $lte:200 }); 

或查詢 OR

"$in" 一個(gè)鍵對(duì)應(yīng)多個(gè)值
"$nin" 同上取反, 一個(gè)鍵不對(duì)應(yīng)指定值
"$or" 多個(gè)條件匹配, 可以嵌套 $in 使用
"$not" 同上取反, 查詢與特定模式不匹配的文檔

this.ctx.model.Book.find({"name":{ $in: ["射雕","倚天"]} );

刪除數(shù)據(jù)

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

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

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

conditions為條件,update是更新的值對(duì)象

排序

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

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

限制數(shù)量

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

number表示限制的個(gè)數(shù)

跳過(guò)文檔返回

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

number表示跳過(guò)的個(gè)數(shù),skip經(jīng)常搭配limit實(shí)現(xiàn)分頁(yè)的功能

條件數(shù)組and

在find后面可使用and對(duì)查詢結(jié)果進(jìn)行進(jìn)一步條件篩選,相當(dāng)于并且的意思。

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)

關(guān)聯(lián)查詢populate

// 在model中配置字段時(shí)候指定關(guān)聯(lián)的表名,就可以通過(guò)populate來(lái)進(jìn)行表的關(guān)聯(lián)查詢
user: { /* 書(shū)籍發(fā)布者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 表關(guān)聯(lián)

批量操作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);

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

mongoose還有非常多的方法可以提供給我的靈活使用,我們?cè)谑褂玫臅r(shí)候可以結(jié)合業(yè)務(wù)邏輯選擇合適的方法來(lái)提高我們操作數(shù)據(jù)庫(kù)的效率。在我們使用它之前可以認(rèn)真的閱讀官方文檔

總結(jié)

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

您可能感興趣的文章:
  • egg.js的基本使用和調(diào)用數(shù)據(jù)庫(kù)的方法示例
  • 關(guān)于自定義Egg.js的請(qǐng)求級(jí)別日志詳解
  • KOA+egg.js集成kafka消息隊(duì)列的示例
  • mongoose更新對(duì)象的兩種方法示例比較
  • 關(guān)于在mongoose中填充外鍵的方法詳解
  • 利用Mongoose讓JSON數(shù)據(jù)直接插入或更新到MongoDB
  • 詳解Nodejs基于mongoose模塊的增刪改查的操作
  • 關(guān)于mongoose連接mongodb重復(fù)訪問(wèn)報(bào)錯(cuò)的解決辦法

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Mongoose 在egg中的使用詳解》,本文關(guān)鍵詞  Mongoose,在,egg,中的,使用,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Mongoose 在egg中的使用詳解》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Mongoose 在egg中的使用詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    色综合天天综合网国产成人综合天| 一区二区三区自拍| 久久福利视频一区二区| 91精品婷婷国产综合久久竹菊| 午夜日韩在线观看| 日韩欧美国产一二三区| 国内精品伊人久久久久影院对白| 欧美成人aa大片| 高清av一区二区| **性色生活片久久毛片| 在线看不卡av| 日本亚洲天堂网| 久久久久久久久岛国免费| 成人福利视频在线看| 亚洲国产精品人人做人人爽| 91精品国产品国语在线不卡| 国产一区日韩二区欧美三区| 亚洲三级免费观看| 8v天堂国产在线一区二区| 国产精品自拍av| 亚洲美女偷拍久久| 日韩一区二区三区观看| 成人网男人的天堂| 午夜a成v人精品| 久久久精品免费网站| 91视频观看视频| 欧美a一区二区| 国产精品久久久久久久久免费樱桃 | 久久久久久久久97黄色工厂| 丁香另类激情小说| 午夜精品福利在线| 国产女人18水真多18精品一级做| 欧美性三三影院| 国产一区在线精品| 亚洲一区二区美女| 久久先锋影音av鲁色资源网| 91久久久免费一区二区| 久久99精品国产.久久久久久| 中文字幕一区二区三区蜜月| 欧美一区二区三区公司| 色综合久久久久| 九九精品一区二区| 亚洲综合激情另类小说区| 欧美成人在线直播| 欧美日韩国产综合视频在线观看| 国产成人av资源| 麻豆一区二区三区| 亚洲第一福利一区| 亚洲欧美日韩成人高清在线一区| 精品免费日韩av| 777欧美精品| 欧洲一区二区三区在线| 波多野结衣一区二区三区 | 久久99精品一区二区三区三区| 亚洲伦理在线精品| 中文字幕在线一区免费| 久久精品免视看| 2014亚洲片线观看视频免费| 欧美一区二区三区视频免费| 91一区一区三区| 99精品视频在线观看免费| 国产一本一道久久香蕉| 裸体健美xxxx欧美裸体表演| 午夜久久久久久久久| 亚洲国产成人tv| 亚洲成人综合网站| 一区二区三区精品视频| 亚洲天堂精品在线观看| 亚洲欧洲色图综合| 国产精品动漫网站| 中文字幕一区二区三| 国产欧美精品一区aⅴ影院| 亚洲精品在线网站| 精品卡一卡二卡三卡四在线| 精品国产污网站| 欧美mv日韩mv国产| 欧美电影免费提供在线观看| 欧美日韩高清一区二区| 欧美日韩另类国产亚洲欧美一级| 日本高清不卡视频| 欧美日韩黄色一区二区| 日韩精品欧美精品| 香蕉av福利精品导航| 午夜精品久久久久久不卡8050| 亚洲国产精品综合小说图片区| 午夜久久福利影院| 免费精品视频在线| 国产激情视频一区二区在线观看| 国产另类ts人妖一区二区| 国产福利一区在线| 成人av动漫在线| 91视频免费观看| 欧美高清性hdvideosex| 日韩美女在线视频| 国产日韩欧美精品电影三级在线| 久久久777精品电影网影网| 中文字幕 久热精品 视频在线 | 欧美色欧美亚洲另类二区| 欧美精品高清视频| 精品日韩在线一区| 中文字幕人成不卡一区| 亚洲第一精品在线| 国产一区二区成人久久免费影院| 国产中文一区二区三区| 色哟哟在线观看一区二区三区| 欧美婷婷六月丁香综合色| 日韩三级高清在线| 国产精品午夜久久| 在线观看欧美黄色| 久久伊人蜜桃av一区二区| 中文字幕五月欧美| 免费一级片91| 99麻豆久久久国产精品免费优播| 欧美三级一区二区| 国产日韩精品一区二区浪潮av| 亚洲男人电影天堂| 精东粉嫩av免费一区二区三区| 成人精品在线视频观看| 欧美军同video69gay| 国产精品每日更新| 日韩中文字幕麻豆| 国产成人综合在线观看| 欧美羞羞免费网站| 久久久www免费人成精品| 亚洲成人资源在线| 9色porny自拍视频一区二区| 日韩丝袜情趣美女图片| 一区二区三区中文字幕| 国产一区二区久久| 制服.丝袜.亚洲.中文.综合| 国产精品嫩草影院com| 免费高清在线一区| 欧美在线影院一区二区| 国产欧美日韩三级| 久久福利资源站| 欧美日韩高清一区二区不卡| 岛国av在线一区| 欧美xxxxx裸体时装秀| 性久久久久久久| 99精品欧美一区二区三区小说 | 中文字幕一区二区5566日韩| 日韩激情一二三区| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 奇米色777欧美一区二区| 成人av电影观看| 亚洲精品在线一区二区| 久久机这里只有精品| 欧美日韩中文另类| 亚洲国产视频在线| 色偷偷一区二区三区| 中文字幕亚洲区| 国产成人超碰人人澡人人澡| 久久久99久久精品欧美| 麻豆成人免费电影| 欧美成人精精品一区二区频| 免费一级欧美片在线观看| 在线播放/欧美激情| 日韩1区2区日韩1区2区| 7777精品久久久大香线蕉| 亚洲综合在线免费观看| 色婷婷精品久久二区二区蜜臀av| 国产精品传媒入口麻豆| 国产成人精品在线看| 久久久精品综合| 国产盗摄一区二区| 欧美国产乱子伦 | 91麻豆成人久久精品二区三区| 国产精品午夜春色av| 国产91精品一区二区麻豆亚洲| 日本一区二区三区久久久久久久久不 | 欧美国产一区视频在线观看| 精品一区二区三区免费播放| 91精品福利在线一区二区三区| 视频一区二区国产| 日韩一级黄色片| 国产精品一区二区三区四区| 久久日韩精品一区二区五区| 国产成人精品www牛牛影视| 国产精品成人免费精品自在线观看| 91视频一区二区三区| 五月婷婷久久综合| 日韩视频一区二区三区| 国产在线播精品第三| 中文字幕日韩一区| 欧美美女一区二区三区| 九九视频精品免费| 国产精品久久福利| 欧美少妇一区二区| 韩国精品主播一区二区在线观看| 久久久噜噜噜久噜久久综合| 91视频免费观看| 蜜桃av一区二区在线观看| 久久久久九九视频| 色天天综合色天天久久| 麻豆成人在线观看| 国产精品久久久久影院色老大| 欧美午夜精品久久久久久超碰| 日韩国产在线一| 亚洲国产高清aⅴ视频| 欧美男生操女生|