设为首页 收藏本站
查看: 1034|回复: 0

[经验分享] Nodejs中Mongodb的基本使用

[复制链接]

尚未签到

发表于 2017-2-24 10:17:58 | 显示全部楼层 |阅读模式
Node.js的Mongodb使用

安装mongodb模块 npm install --save mongodb

数据库连接
var MongoClient = require('mongodb').MongoClient;  
var assert = require('assert');
  

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

插入数据

插入一个文档对象
var MongoClient = require('mongodb').MongoClient;  
var assert = require('assert');
  

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

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

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

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

简单的insertMany操作
var MongoClient = require('mongodb').MongoClient,  test = require('assert');
  

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

使用Promise的批量插入操作!
var MongoClient = require('mongodb').MongoClient,  test = require('assert');
  
MongoClient.connect('mongodb://localhost:27017/test', (err,db) => {
  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)的批量插入操作
var MongoClient = require('mongodb').MongoClient,  test = require('assert'),
  co = require('co');
  
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,options,callback)(如果没有callback函数,本身返回一个Promise对象)

简单的插入操作
var MongoClient = require('mongodb').MongoClient,  test = require('assert');
  
MongoClient.connect('mongodb://localhost:27017/test',(err,db)=>{
  var blog = db.collection('blog');
  blog.insertOne({name:"xiaos"},(err,r) => {
  test.equal(null,err);
  test.equal(1,r.insertedCount);
  db.close();
  });
  
});

使用Promise的插入操作
var MongoClient = require('mongodb').MongoClient,  test = require('assert');
  
MongoClient.connect('mongodb://localhost:27017/test',(err,db)=>{
  var blog = db.collection('blog');
  blog.insertOne({name:"xiaos"}).then((r)=>{
  test.equal(1,r.insertedCount);
  db.close();
  });
  
});

使用生成器的插入操作
var MongoClient = require('mongodb').MongoClient,  test = require('assert'),
  co = require('co');
  
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,options,callback) return Promise if no callback
var MongoClient = require('mongodb').MongoClient,  test = require('assert');
  

  
MongoClient.connect()

isCapped(callback) return Promise if no callback
var MongoClient = require('mongodb').MongoClient,  test = require('assert');
  
MongoClient.connect('mongodb://localhost:27017/test',(err,db) => {
  db.createCollection('newBlog',{'capped':true,'size':1024},(err,collection) => {
  test.equal('newBlog',collection.collectionName);        
  collection.isCapped((err,capped) => {
  test.equal(true,capped);
  db.close();
  });
  });
  
});
  capped collection是指固定大小的集合,新元素插入后会覆盖掉旧的元素,保持整个集合的大小不变。
//在命令行中输入mongo  
//创建一个1024大小的myCappedCollection集合
  
db.createCollection('myCappedCollection',{'capped':true,'size':1024});
  
//插入1000条记录
  
for (var i = 1;i <= 1000;i++){
  db.myCappedCollection.save({id:i,name:'xiaos'+i});
  
}
  
//查询文档个数
  
db.myCappedCollection.count()
  
//实际只有18个文档id为983-1000 即新元素覆盖了旧元素

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-346506-1-1.html 上篇帖子: 安装 nodejs图像处理模块 sharp 下篇帖子: NodeJs回调操作Promise化
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表