eggjs连接mysql_使用 egg-mongoose 在 Eggjs 中连接 Mongodb 数据库 - 文章

egg-mongoose 是 Egg.js 版本的 mongoose 插件,可以很方便的连接和管理 Mongodb 数据库,支持多连接和集群等功能。

安装

$ npm i egg-mongoose --save

配置

改变 {app_root}/config/plugin.js 来启用 egg-mongoose 插件:

exports.mongoose = {

enable: true,

package: 'egg-mongoose',

};

简单连接

配置

// {app_root}/config/config.default.js

exports.mongoose = {

url: 'mongodb://127.0.0.1/example',

options: {},

};

// recommended

exports.mongoose = {

client: {

url: 'mongodb://127.0.0.1/example',

options: {},

},

};

示例

// {app_root}/app/model/user.js

module.exports = app => {

const mongoose = app.mongoose;

const Schema = mongoose.Schema;

const UserSchema = new Schema({

userName: { type: String },

password: { type: String },

});

return mongoose.model('User', UserSchema);

}

// {app_root}/app/controller/user.js

exports.index = function* (ctx) {

ctx.body = yield ctx.model.User.find({});

}

多连接

配置

// {app_root}/config/config.default.js

exports.mongoose = {

clients: {

// clientId, access the client instance by app.mongooseDB.get('clientId')

db1: {

url: 'mongodb://127.0.0.1/example1',

options: {},

},

db2: {

url: 'mongodb://127.0.0.1/example2',

options: {},

},

},

};

示例

// {app_root}/app/model/user.js

module.exports = app => {

const mongoose = app.mongoose;

const Schema = mongoose.Schema;

const conn = app.mongooseDB.get('db1');

const UserSchema = new Schema({

userName: { type: String },

password: { type: String },

});

return conn.model('User', UserSchema);

}

// {app_root}/app/model/book.js

module.exports = app => {

const mongoose = app.mongoose;

const Schema = mongoose.Schema;

const conn = app.mongooseDB.get('db2');

const BookSchema = new Schema({

name: { type: String },

});

return conn.model('Book', BookSchema);

}

// app/controller/user.js

exports.index = function* (ctx) {

ctx.body = yield ctx.model.User.find({}); // get data from db1

}

// app/controller/book.js

exports.index = function* (ctx) {

ctx.body = yield ctx.model.Book.find({}); // get data from db2

}

默认配置

访问 config/config.default.js 查看更多细节。

Mongo集群支持

// {app_root}/config/config.default.js

exports.mongoose = {

client: {

url: 'mongodb://mongosA:27501,mongosB:27501',

options: {

mongos: true,

},

},

};

相关链接

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 安装mongoose 在命令行执行以下命令: ``` npm install mongoose ``` 2. 连接数据库 在Node.js使用mongoose连接数据库需要先引入mongoose模块: ```javascript const mongoose = require('mongoose') ``` 接着使用mongoose.connect()方法连接数据库: ```javascript mongoose.connect('mongodb://localhost:27017/databaseName', { useNewUrlParser: true }) ``` 其mongodb://localhost:27017/databaseName是连接数据库的URL,其localhost为数据库服务器地址,27017为MongoDB的默认端口号,databaseName为要连接数据库名称。 { useNewUrlParser: true }是Mongoose的一个选项,以允许在连接使用新的URL字符串解析器。 3. 定义Schema和Model 在使用mongoose之前,需要先定义Schema和Model。Schema是用来定义数据结构的,Model是由Schema生成的实例。 ```javascript const Schema = mongoose.Schema const userSchema = new Schema({ username: String, password: String, email: String }) const User = mongoose.model('User', userSchema) ``` 以上代码定义了一个名为User的Model,该Model对应的Schema定义了三个属性:username、password和email。 4. CRUD操作 通过定义好的Model可以进行CRUD操作。以下是一些常用的操作: - 新增数据 ```javascript const user = new User({ username: 'Tom', password: '123456', email: '[email protected]' }) user.save(function (err, user) { if (err) return console.error(err) console.log(user.username + ' saved to database.') }) ``` - 查询数据 ```javascript User.find(function (err, users) { if (err) return console.error(err) console.log(users) }) ``` - 更新数据 ```javascript User.findOneAndUpdate({ username: 'Tom' }, { password: '654321' }, function (err, user) { if (err) return console.error(err) console.log(user) }) ``` - 删除数据 ```javascript User.deleteOne({ username: 'Tom' }, function (err) { if (err) return console.error(err) console.log('User deleted.') }) ``` 以上代码演示了如何使用mongoose连接MongoDB数据库,并进行CRUD操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值