Node.js的Mongodb使用实例

前端之家收集整理的这篇文章主要介绍了Node.js的Mongodb使用实例前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

安装mongodb模块 npm install --save mongodb

数据库连接

//连接test数据库
var url = 'mongodb://localhost:27017/test';
MongoClient.connect(url,(err,db) => {
assert.equal(null,err);
console.log('连接成功');
db.close();
});

插入数据

插入一个文档对象

//test数据库的路径
var url = 'mongodb://localhost:27017/test';

//插入文档
var insertDocument = (db,callback) => {
//在test库下blog集合中 新增json文档
db.collection('blog').insertOne({
name:"xiaos",age:22
},result) => {
assert.equal(err,null);
console.log('新增文档成功');
callback();
});
};

//插入操作
MongoClient.connect(url,err);
insertDocument(db,()=>{
db.close();
});
});

批量插入操作:insertMany(doc,options,callback)(如果没有callback函数,本身返回一个Promise对象)

简单的insertMany操作

MongoClient.connect('mongodb://localhost:27017/test',db) => {
var blog = db.collection('blog');
//新增两个文档对象
blog.insertMany([{name:"shen"},{name:"fzq"}],r) => {
test.equal(null,err);
//回调函数中返回的r为执行完插入操作的对象,insertedCount属性为已经插入的对象个数
test.equal(2,r.insertedCount);
db.close();
});
});

使用Promise的批量插入操作!

{ var blog = db.collection('blog'); blog.insertMany([{name:"xiaosGG"},{name:"fzqDD"}]).then((r) => { test.equal(2,r.insertedCount); db.close(); }); });

因为mongodb和nodejs都是异步io的机制,所有几乎所有耗时的操作都是以回调函数的方式完成。但是因为回调函数的层次嵌套,一段代码后面可能会跟上一大段的 });,随着层级的增加代码变得不易理解和维护。所有在使用MongoDB时,推荐用Promise的方式来解决回调嵌套的问题。

从上面的代码可以看出,insertMany([obj...])返回一个Promise对象,我们用.then((r)=>{})接收正常的回调值,用.catch((err) => {})来抓取异常。

使用生成器(Generator)的批量插入操作

co(function*(){
var db = yield MongoClient.connect('mongodb://localhost:27017/test');
var blog = db.collection('blog');
var r = yield blog.insertMany([{name:"xiaosBB"},{name:"fzqMM"}]);
test.equal(2,r.insertedCount);
db.close();
});

单个文档插入:

insertOne(doc,callback)(如果没有callback函数,本身返回一个Promise对象)

简单的插入操作

{ var blog = db.collection('blog'); blog.insertOne({name:"xiaos"},err); test.equal(1,r.insertedCount); db.close(); }); });

使用Promise的插入操作

{ var blog = db.collection('blog'); blog.insertOne({name:"xiaos"}).then((r)=>{ test.equal(1,r.insertedCount); db.close(); }); });

使用生成器的插入操作

co(function*(){
var db = yield MongoClient.connect('mongodb://localhost:27017/test');
var blog = db.collection('blog');
var r = yield blog.insertOne({name:"xiaosBB"});
test.equal(1,r.insertedCount);
db.close();
});

mapReduce(map,reduce,callback) return Promise if no callback

MongoClient.connect()

isCapped(callback) return Promise if no callback

{ db.createCollection('newBlog',{'capped':true,'size':1024},collection) => { test.equal('newBlog',collection.collectionName); collection.isCapped((err,capped) => { test.equal(true,capped); db.close(); }); }); });

capped collection是指固定大小的集合,新元素插入后会覆盖掉旧的元素,保持整个集合的大小不变。

查询文档个数 db.myCappedCollection.count() //实际只有18个文档id为983-1000 即新元素覆盖了旧元素

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

猜你在找的Node.js相关文章