Mongoose为操作MongoDB数据库提供了很大的方便,在实际开发过程中,为了保证可扩展与可维护性,通常会将Mongoose进行模块化,下面记录一个模块化的实例,便于在以后的项目中复用。
1. 定义db.js,连接数据库
代码语言:javascript复制var mongoose = require('mongoose');
mongoose.connect('mongodb://127.0.0.1:27017/test', { useNewUrlParser: true }, function (err) {
if (err) {
console.log(err);
return;
}
console.log('数据库连接成功')
});
module.exports = mongoose
连接参数说明:
第一个参数为数据库的地址,如果设置了密码的话,记得加上用户名和密码,格式如下:
mongodb://test_admin:123456@127.0.0.1:27017/test
第二个参数 useNewUrlParser 属性会在url里识别验证用户所需的数据库,4.x以上的版本需要加,否则会有警告产生。
第三个参数 为回调函数用来确认数据库是否连接成功。
2. 引入定义的db.js文件,生成schema,建立模型并导出,文件名为user.js
代码语言:javascript复制var mongoose=require('./db.js');
var UserSchema=mongoose.Schema({
name:String,
age:Number,
// 指定默认参数
status:{
type:Number,
default:1
}
})
module.exports=mongoose.model('User',UserSchema,'user');
3. 在需要操作数据的页面引入定义的user.js,执行相关操作。
代码语言:javascript复制var UserModel=require('./model/user.js');
var user=new UserModel({
name:"李四",
age:40
})
// 执行新增操作
user.save(function(err){
if(err){
console.log(err);
return;
}
// 获取user表的数据
UserModel.find({},function(err,docs){
if(err){
console.log(err);
return;
}
console.log(docs);
})
})
大家可能发现在定义schema时,引入了db.js文件,即连接了一次数据库,那么调用多个schema时,是否会多次连接数据库了,其实在mongoose的底层已经做了单例模式的处理,也就是说只会在第一次连接时比较耗时,后续的连接执行都会很快。