安装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 即新元素覆盖了旧元素
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]