Mongoose是什么?如何使用?
Admin 2021-05-12 群英技术资讯 1162 次浏览
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还有非常多的方法可以提供给我的灵活使用,我们在使用的时候可以结合业务逻辑选择合适的方法来提高我们操作数据库的效率。在我们使用它之前可以认真的阅读官方文档。
总结
相信现在大家对于Mongoose的用法应该都有一定的了解了,关于Mongoose就介绍到这,希望本文对大家学习有帮助,想要了解更多Mongoose使用技巧大家可以关注其他文章。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
MongoDB权限认证怎么启用?对于MongoDB不是很熟悉的朋友,可能对用户开启权限认证的方法步骤不是很了解,下面小编就和大家介绍一下MongoDB开启权限认证的方法。
TTL索引用于什么,怎样使用的呢?有不少朋友对此感兴趣,下面小编给大家整理和分享了相关知识和资料,易于大家学习和理解,有需要的朋友可以借鉴参考,下面我们一起来了解一下吧。
我们知道mongodb是分布式文档存储数据库,而mongodb部署架构分为单机,可复制集和分片群集。其中,分片群集是比较复杂,而且运维难度比较高的。很多人对于mongodb分片集群都不是很理解,这篇文章就给大家介绍一下MongoDB分片集群的问题。
MongoDB是一个基于分布式文件存储的数据库,是由C++语言编写的,目的在于为web应用听可扩展的高性能数据存储解决方案。MongoDB与SQL还是存在很大不同的,例如它没有像 SQL 一样有自动增长的功能,那么mongodb字段值自增长要如何实现呢?
Node.js 连接 MongoDB MongoDB是一种文档导向数据库管理系统,由C++撰写而成。 本章节我们将为大家介绍如何使用 Node.js 来连接 MongoDB,并对数据库进行操作。 如果你还没有 MongoDB 的基本知识,可以参考我们的教程:MongoDB 教程。 安装驱动 本教程使用了淘宝定制的 cnpm 命令进行安装: $ cnpm install mongodb 接下来我们来实现增删改查功能。 创建数据库 ..
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008