最近尝试了一下Node的代码,过程中用到了数据库,现在总结一下并分享出来。

对于Mongodb的安装,大家可以参考下这篇博客,保证良心,对了,是windows系统的。


1. 安装,这里用到的管理工具是yarn.
yarn install
2.连接数据库
const mongoose = require('mongoose');

try{
    mongoose.connect('mongodb://localhost/test',{
        useMongoClient:true
    })
}catch(error){
    console.log(err)
}

mongoose.connection.once("open",function(){
    console.log('数据库连接成功');
}).on('error',function(err){
    throw err
})

这里做一下解释,test是本地创建的一个数据库,连接之后可以直接进行操作,未成功连接则直接抛出错误。

使用useMongoClient:true 可以避免Mongoose报出警告,还有一些其他的选项可以自己添加,可以参考这里

3.创建数据库表并连接

首先新建一个在最外层结构新建一个models文件夹,然后文件夹中新建login.js文件。

module.exports = function (mongoose) {
    var schema = mongoose.Schema({
        userName: {
            type: String,   //指定字段类型
            required:true,  //判断数据是否必须(如果存在一条数据)
            unique:true   //是否为不可重复
        },
        pass:{
            type:String
        }
    });
    return mongoose.model('User', schema);   //第一个变量是数据库表名,第二个是使用的模板
}

对于上面的type,required等约束字符,想实现更多复杂功能可以了解这里

然后在文件夹中新建index.js文件。

module.exports = function (instance) {
    return {
        User: require('./login')(instance)
    }
}

按照规律可以新建更多的模型文件,统一通过index.js导出

最后,要在app中把导出的model添加到ctx上。

mongoose.connection
    .once("open",function(){
        console.log('mongoose connection')
        const models = require('./models')(mongoose)   //引入模型
        app.use(async (ctx,next) => {    
            ctx.models = models;  //将模型的信息放到ctx中。
            await next();
        })
    })
    .on('error',function(error){
        throw error
    })

这样之后就可以在项目中通过ctx直接调用数据库的访问操作了。

4.访问网络进行数据库操作

在一个负责处理signin的controller里面(不清楚的可以参照上述廖雪峰的网站),其实只要是个可以处理post请求的原生操作也可以,这里不细说。

'POST /zhuce': async (ctx, next) => {
        var userName = ctx.request.body.userName || '';   //获取post的参数
        var pass = ctx.request.body.pass || '';
        console.log(ctx.request)
        var user = new ctx.models.User({      //根据scheme生成对象
            userName:userName,
            pass:pass
        })
        user.save((err,rst) => {     //调用mongoose方法实现保存操作。
            if (err) {     //打印错误信息
                console.log("Error:" + err);
            }
            else {
                console.log("Res:" + rst);
            }
        })
    },

由于是后台的处理操作,所以这里就不涉及前端知识了,直接用Postman来测试。我使用的端口为8080.

nodejs 连接 mongodb 分片集群 nodejs mongodb连接池_数据库

nodejs 连接 mongodb 分片集群 nodejs mongodb连接池_mongodb_02

这样就可以注册成功了,由于名字设定的是unique,所以注意名字不要重复。

5.验证操作是否成功

这里有一点要注意一下,我们给数据库起得名字叫做User,但是数据库中生成的数据库名称为users,这应该是mongoose帮忙转换的。

nodejs 连接 mongodb 分片集群 nodejs mongodb连接池_node_03