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

首頁 > 數據庫 > MongoDB > 正文

Mongoose是什么?如何使用?

2024-09-07 00:22:29
字體:
來源:轉載
供稿:網友
       Mongoose是什么?如何使用?對于剛接觸MongoDB朋友來說,可能對用戶Mongoose并不是很了解,這篇文章小編就給大家介紹一下Mongoose以及使用,感興趣的朋友可以了解一下。
 
        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還有非常多的方法可以提供給我的靈活使用,我們在使用的時候可以結合業務邏輯選擇合適的方法來提高我們操作數據庫的效率。在我們使用它之前可以認真的閱讀官方文檔。

(編輯:武林網)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品小视频在线| 91情侣偷在线精品国产| 亚洲性生活视频| 911国产网站尤物在线观看| 欧美国产第一页| 午夜精品久久17c| 欧美亚洲视频在线看网址| 超碰91人人草人人干| 亚洲tv在线观看| 7m精品福利视频导航| 国产日韩中文字幕| 久久人人爽人人爽人人片av高请| 午夜精品久久久久久久99热| 国内精品久久久久久中文字幕| 亚洲图片在线综合| 国产精品美女主播在线观看纯欲| 欧美大奶子在线| 国产日韩欧美夫妻视频在线观看| 九九精品在线观看| 午夜精品蜜臀一区二区三区免费| 欧洲一区二区视频| 91精品国产91久久久| 亚洲一区二区三区视频| 国产精品爽黄69| 97视频com| 国产亚洲免费的视频看| 色999日韩欧美国产| 国产成人精品一区| 日韩在线中文字幕| 日韩一区二区av| 欧美成人午夜激情视频| 69av视频在线播放| 国产一区二区三区丝袜| 精品久久久久久电影| 亚洲国产欧美一区| 亚洲女人被黑人巨大进入| 亚洲精品久久久久| 亚洲va欧美va国产综合久久| 91九色综合久久| 热门国产精品亚洲第一区在线| 国产精品亚洲视频在线观看| 欧美精品第一页在线播放| 中文字幕亚洲图片| 欧美日韩裸体免费视频| 国产999视频| 亚洲影院色在线观看免费| 亚洲精品美女久久久| 国内免费精品永久在线视频| 中文字幕视频在线免费欧美日韩综合在线看| 日韩欧美一区视频| 亚洲欧美日韩一区二区三区在线| 亚洲人成在线观看| 国产精品一区久久| 精品综合久久久久久97| 国产精品高潮呻吟久久av无限| 久久久www成人免费精品| 91高潮在线观看| 97色在线观看免费视频| 欧美色视频日本高清在线观看| 伊人亚洲福利一区二区三区| 尤物99国产成人精品视频| 91精品综合视频| 欧美综合一区第一页| 久久男人资源视频| 成人性生交xxxxx网站| 中文字幕欧美日韩在线| 成人av番号网| 狠狠做深爱婷婷久久综合一区| 亚洲香蕉成人av网站在线观看| 久久91亚洲精品中文字幕奶水| 亚洲二区在线播放视频| 一区二区三区国产在线观看| 亚洲图片欧洲图片av| 伊人久久综合97精品| 欧美性猛交丰臀xxxxx网站| 久久久精品国产亚洲| 91精品国产自产在线观看永久| 都市激情亚洲色图| 中文字幕亚洲天堂| 成人xvideos免费视频| 欧美大片va欧美在线播放| 日韩精品极品视频免费观看| 91精品国产91久久久久久吃药| 欧美一级淫片播放口| 日韩免费黄色av| 国产欧美中文字幕| 日韩免费看的电影电视剧大全| 欧美激情影音先锋| 国产精品xxx视频| 日韩经典第一页| 在线色欧美三级视频| 亚洲成人教育av| 国产一区二区激情| 精品久久久久久国产91| 91大神在线播放精品| 伊人伊成久久人综合网站| 日韩av高清不卡| 日本精品一区二区三区在线播放视频| 欧美人在线视频| 91国内揄拍国内精品对白| 欧美乱妇高清无乱码| 日韩激情片免费| 日韩精品在线免费观看| 日本精品免费一区二区三区| 欧美一级在线播放| 亚洲欧美日韩中文视频| 欧美精品亚州精品| 精品国产一区二区三区久久狼黑人| 奇米影视亚洲狠狠色| 国产91久久婷婷一区二区| 亚洲字幕一区二区| 亚洲精品综合久久中文字幕| 亚洲国产成人久久| 久久久久女教师免费一区| 日本不卡高字幕在线2019| 欧美片一区二区三区| 中文字幕久久久| www高清在线视频日韩欧美| 国产精品jvid在线观看蜜臀| 国产精品精品一区二区三区午夜版| 国产成人亚洲综合91精品| 91系列在线观看| 亚洲一区二区三区视频播放| 国产精品成人一区二区三区吃奶| 91精品国产高清久久久久久91| 91精品国产综合久久久久久蜜臀| 蜜臀久久99精品久久久无需会员| 91免费版网站入口| 亚洲欧美国产一区二区三区| 最近中文字幕mv在线一区二区三区四区| 成人激情视频在线观看| 国产一区二区三区丝袜| 欧美成人小视频| 国产成人精品久久二区二区91| 中文一区二区视频| 7777精品久久久久久| 欧美一级视频一区二区| 国产在线视频不卡| 欧美另类极品videosbestfree| 色偷偷偷亚洲综合网另类| 美女av一区二区| 78m国产成人精品视频| 欧美电影免费播放| 7777免费精品视频| 日韩欧美在线免费| 国产乱人伦真实精品视频| 午夜精品一区二区三区在线播放| 欧美精品电影免费在线观看| 一本一本久久a久久精品牛牛影视| 欧美老少做受xxxx高潮| 国产美女高潮久久白浆| 国产美女精品视频免费观看| 亚洲淫片在线视频| 欧洲亚洲免费在线| 超碰日本道色综合久久综合| 久久精品人人做人人爽| 欧美日韩午夜视频在线观看| 97免费视频在线播放| 亚洲香蕉伊综合在人在线视看| 在线成人中文字幕| 久久久久久69| 97超碰蝌蚪网人人做人人爽| 国产精品扒开腿做爽爽爽男男| 在线观看日韩欧美|