通过使用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会返回的第二个参数即本次查询所取得的文档对象