一、方法一 

Egg连接Mongodb

 

Cnpm i egg-mongo-native  --save

Plugin.js中配置

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

Config.default.js配置

config.mongo = {
client: {
host:"127.0.0.1",
port:"",
name:"test",
user:"",
password:"",
options:{},
}
}

查询语句使用

var result = await this.app.mongo.find('users')

二、方法二(推荐)

Egg中使用Mongoose连接数据库

https://www.npmjs.com/package/egg-mongoose

配置

npm i egg-mongoose --save
exports.mongoose = {
  enable: true,
  package: 'egg-mongoose',
};
//config中配置mongose连接mongodb数据库
Mongodb://eggadmin:123456@localhost:27017 //有用户名密码的情况
exports.mongoose = {
client: {
url: 'mongodb://127.0.0.1/eggxiaomi',
options: {
useNewUrlParser: true,
},
}
};

Schema的建立数据表集合的映射新建app/module文件夹新增 order.js

module.exports = app => {
const mongoose = app.mongoose;
const Schema = mongoose.Schema;
const OrderSchema = new Schema({
order_id: { type: String },
uid: { type: String },
trade_no: { type: String },
all_price: { type: Number },
all_num: { type: Number },
});
return mongoose.model('Order', OrderSchema,'order'); //返回model
}

Model的建立

增加数据

Let addResult=this.ctx.request.body;
Let admin=new this.ctx.model.Order(addResult);
admin.save();

修改数据

await this.ctx.model.Admin.updateOne({"_id":id},{
mobile,email,role_id})

查询

Let id=this.ctx.request.query.id;
Let result=await this.ctx.model.Admin.find({"_id":id});

删除数据

await this.ctx.model[model].deleteOne({"_id":id}); 

数据预设

Mongoose 预定义模式修饰符,可以对我们增加的数据进行一些格式
Lowercase uppercase trim
Set()//建议使用mongoose,增加数据时匹配
Sn:{
Type:string
Trim:true //是否去掉空格
index: //索引
set(parmas){
if(parmas.indexOf('http://')==){
return 'http://'+parmas
}
return parmas
}

数据校验

Required
Max
Min
Enum 枚举类型
Match 增加的数据必须符合match正则
Maxlength 最大值
Minlength 最小值
Name:{
Type:string
Required:true,
Min:,
Max:,
Enum:[,,,], 枚举类型
Match:/sn(.*)/i //必须sn开头
}
自定义方法
validate:function(desc){
return desc.length>=;
}

Mongoose中多对多的数据查询,和aggregate聚合管道

管道操作

$project

增加,删除,重命名字段

$match

条件匹配,只满足条件的文档才能进入下一阶段

$limit

限制结果的数量

$skip

跳过文档的数量

$sort

条件排序

$group

条件组合结果 统计

$lookup

用以引入其它集合的数据

sql和nosql对比

Where

$match

group

$group

having

$match

select

$project

Order by

Limit

$sort

$limit

Sum()

$sum

Count()

$sum

join

$lookup

常用表达式操作符

Description

$addToSet

将文档指定字段的值去重

$max

文档指定字段的最大值

$min

文档指定字段的最小值

$sum

文档指定字段求和

$avg

文档指定字段求平均

$gt

大于给定值

$lt

小于给定值

$eq

等于给定值

var result=await this.ctx.model.Admin.aggregate([{
$lookup:{
from:'role',
localField:'role_id',
foreignField:'_id',
as:'role'
}
},
{
$match:{'role_id':}
}
])

聚合管道的使用

db.order.aggregate([
{
$project:{ trade_no:, all_price: }
},
{
$match:{"all_price":{$gte:}}
},
{
$sort:{"all_price":-}
},
{
$skip:
} ])

egg.js连接和使用Mongodb的更多相关文章

  1. 在egg.js中使用mongodb

    1.egg.js官网只推荐了mysqle,要用mongodb得另找资料.通过查找,大家都在用Mongoose连接,于是乎学习. 网站链接:https://www.npmjs.com/package/e ...

  2. Node.js连接MongoDB数据库

    首先要启动MongoDB服务器 先找到你的mongoDb安装目录,我的如下:就在bin文件夹下创建一个data文件夹,data内包含两个空文件夹,如下: 接着回到bin文件夹处,按住shift键,右击 ...

  3. 基于 Egg.js 框架的 Node.js 服务构建之用户管理设计

    前言 近来公司需要构建一套 EMM(Enterprise Mobility Management)的管理平台,就这种面向企业的应用管理本身需要考虑的需求是十分复杂的,技术层面管理端和服务端构建是架构核 ...

  4. node.js连接MySQL操作及注意事项

    node.js作为服务端的js运行环境已经出现了有几年了,最近我有个朋友也在做这方面的开发,但是也是刚刚接触,遇到了很多坑.前几天他们在操作数据库的时候出现了点问题,后来我们一起看了看,其实都是nod ...

  5. node.js操作数据库之MongoDB+mongoose篇

    前言 node.js的出现,使得用前端语法(javascript)开发后台服务成为可能,越来越多的前端因此因此接触后端,甚至转向全栈发展.后端开发少不了数据库的操作.MongoDB是一个基于分布式文件 ...

  6. Serverless + Egg.js 后台管理系统实战

    本文将介绍如何基于 Egg.js 和 Serverless 实现一个后台管理系统 作为一名前端开发者,在选择 Nodejs 后端服务框架时,第一时间会想到 Egg.js,不得不说 Egg.js 是一个 ...

  7. egg.js in action

    egg.js in action fullstack https://github.com/eggjs/egg/ cli config router service midlewares HTTP C ...

  8. Node.js连接Mysql,并把连接集成进Express中间件中

    引言 在node.js连接mysql的过程,我们通常有两种连接方法,普通连接和连接池. 这两种方法较为常见,当我们使用express框架时还会选择使用中间express-myconnection,可以 ...

  9. Node.js、express、mongodb 实现分页查询、条件搜索

    前言 在上一篇Node.js.express.mongodb 入门(基于easyui datagrid增删改查) 的基础上实现了分页查询.带条件搜索. 实现效果 1.列表第一页. 2.列表第二页 3. ...

随机推荐

  1. Android之自定义控件

    开发自定义控件的步骤: 1.了解View的工作原理  2. 编写继承自View的子类 3. 为自定义View类增加属性  4. 绘制控件  5. 响应用户消息  6 .自定义回调函数    一.Vie ...

  2. 原来css也可以计算-calc()使用

    在浏览其他人的源代码时,看到了一个陌生的属性:width:calc(100% - 10px -10px); 出于好奇心,百度了一下,看到了以下这篇文章,http://www.w3cplus.com/c ...

  3. LC-BLSTM结构快速解读

    参考文献如下: (1) A Context-Sensitive-Chunk BPTT Approach to Training Deep LSTM/BLSTM Recurrent Neural Net ...

  4. 【hdu6121】 Build a tree 简单数学题

    题目传送门:http://acm.hdu.edu.cn/showproblem.php?pid=6121 我好像推得挺久的诶..... 题目大意:给你一棵有$n$个点的树,根节点为$0$,对于其余节点 ...

  5. eclipseGUI的可视化开发工具插件

    一   各种GUI开发插件的特色 Eclipse并不自带GUI的可视化开发工具,那么如果要在Eclipse进行可视化的GUI开发,就需要依靠第三方的插件. 1. Visual Editor Eclip ...

  6. (转)MySQL备份原理详解

    MySQL备份原理详解 原文:http://www.cnblogs.com/cchust/p/5452557.html 备份是数据安全的最后一道防线,对于任何数据丢失的场景,备份虽然不一定能恢复百分之 ...

  7. 开源微信支付SDK

    应该有一年多没在博客园上写文章了,毕竟是一个记录自己技术成长的平台,没能将写博客长期坚持下来,说起来也是挺惭愧的.对于自己的近况而言,确实平常加班也比较多,时间会比较压缩,所以到后来博客也基本停止了更 ...

  8. 解析xml文件步骤 -- pullparser

    1. 初始化一个xml的解析器 XmlPullParser parser = Xml.newPullParser(); 2. 设置解析器的参数 InputStream inputStream = th ...

  9. Maven 学习笔记(三)

    Maven生命周期 在上次我们使用maven package 对项目进行打包.这里就是为其指定一个生命周期.生命周期是包含在一个项目构建中的一系列有序的阶段.Maven有许多不同的生命周期,比如验证( ...

  10. LDAP落地实战(四):Jenkins集成OpenLDAP认证

    前几篇分文章分别介绍了OpenLDAP的部署管理和维护以及svn.git的接入,今天我们再下一城接入jenkins. 前情提要:LDAP系列文章 LDAP落地实战(一):OpenLDAP部署及管理维护 ...