node.js学习笔记(二)--使用mongoose简单的CRUD操作及测试模块mocha的使用

来源:互联网 发布:防蓝光眼镜有必要知乎 编辑:程序博客网 时间:2024/06/06 02:56

通过使用mongoose模块能够更为方便的对mongodb数据库进行操作,而在测试过程中使用mocha模块能够十分方便的模拟http请求的发送并很方便的测试对数据库的相应操作


1.数据库连接和模型建立

通过如下方式进行数据库连接等操作:

var mongoose=require('mongoose');mongoose.connect('mongodb://localhost/testnews');

可通过如下方式对相应集合(news)建立模型,以便通过模型间接操作数据库:

var NewsSchema=new mongoose.Schema({    title : String,    info : String});var News =mongoose.model('news',NewsSchema);

1.添加数据

可通过建立的模型.save方法轻松完成数据存储:

   var data1=new News({        title : title,        info : info    });    data1.save(function (err) {        if(err){            console.log('保存失败');            callback(1)        }else {            console.log('保存成功!');            callback(2);        }    });

save后的数据各属性可通过其模型实例进行获取:

var queryId=data1.get('id');

2.删除操作

直接通过模型对象的remove方法接收匹配对象即可完成数据的删除:

 News.remove({            _id : id                },function (err) {                if(err){                     console.log('删除失败');                     callback(1);                } else{                     console.log('删除成功');                     callback(2);            }        });

3.更新操作

更新操作要用到$set,如下所示:

News.update({_id:id},{$set:{title:title,info:info}},function (err) {            if(err){                console.log('修改失败');                callback(1)            }else {                console.log('修改成功!');                callback(2);            }        });    })

4.简单查询

这里使用最为简单的一种查询,即通过id字段查询文档,该方法只会返回一个文档:

 News.findById(id, function (err, adventure) {            if(err){                console.log('查询失败');                callback(1)            }else {                console.log('查询成功!');                var data={                    errCode:1,                    id:adventure._id,                    title:adventure.title,                    info:adventure.info                };                callback(2,data);            }        });

findById会返回的第二个参数即本次查询所取得的文档对象

0 0
原创粉丝点击