Mongoose模块化实践

2020-11-26 12:31:15 浏览数 (1)

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的底层已经做了单例模式的处理,也就是说只会在第一次连接时比较耗时,后续的连接执行都会很快。

0 人点赞