微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Nodejs使用Mongodb存储与提供后端CRD服务详解

前言

众所周知JS是脚本语言,脚本语言都需要一个解析器才能运行。对于写在HTML页面里的JS,浏览器充当了解析器的角色。而对于需要独立运行的JS,NodeJS就是一个解析器。

每一种解析器都是一个运行环境,不但允许JS定义各种数据结构,进行各种计算,还允许JS使用运行环境提供的内置对象和方法做一些事情。例如运行在浏览器中的JS的用途是操作DOM,浏览器就提供了document之类的内置对象。而运行在NodeJS中的JS的用途是操作磁盘文件或搭建HTTP服务器,NodeJS就相应提供了fs、http等内置对象。

本文会把一个对象todo对象(有属性{id,name})存储到Mongodb,做查询删除的测试(Create Remove Delete = CRD)。这个测试包括使用Mongodb Shell,使用CallBack古典风格的访问代码,以及使用Await/Async的现代风格的代码。完成这个这个验证后,就可以掌握最初步的Mongodb了。

我使用的Nodejs是10.7 。操作系统环境为Mac OS X High Sierra。

准备环境

安装和运行Mongodb Daemon

rush:bash;"> brew install mongodb mongodb

访问验证

首先执行Mongodb Shell:

rush:bash;"> mongo

输入命令,查询数据库清单:

show dbs local 0.000GB

创建一个数据库

rush:bash;"> use todos

(若database不存在,则会创建一个,此时若不做任何操作直接退出,则MongoDB会删除数据库)

rush:js;"> db.todos.insert({id:1,name:"reco"}) db.todos.insert({id:2,name:"rita"})

查询

rush:js;"> db.todos.find()

{ "_id" : ObjectId("5b727c0846b6c71a98d3af52"),"id" : 1,"name" : "reco" }
{ "_id" : ObjectId("5b727c7046b6c71a98d3af53"),"id" : 2,"name" : "reta" }

删除记录:

rush:js;"> db.todo.remove({id:1})

删除数据库

rush:js;"> db.todo.drop()

使用nodejs方式访问Mongodb

使用nodejs执行类似Shell对对象的CRD,代码如下:

rush:js;"> var MongoClient = require('mongodb').MongoClient; var url = "mongodb://localhost:27017/todos"; MongoClient.connect(url,function(err,db) { if (err) throw err; console.log("Database created!"); var dbo = db.db("todos"); // var myobj = { id: 1,name: "reco" }; // dbo.collection("todo").insertOne(myobj,res) { // if (err) throw err; // console.log("1 document inserted"); // db.close(); // }); var myobj = [ { id: 1,name: 'reco'},{ id: 2,name: 'rita'},]; dbo.collection("todo").insertMany(myobj,res) { if (err) throw err; console.log("Number of documents inserted: " + res.insertedCount); dbo.collection("todo").find({}).toArray(function(err,result) { if (err) throw err; console.log(result); var myquery = { id: 1 }; dbo.collection("todo").deleteMany(myquery,obj) { if (err) throw err; console.log("document deleted"); db.close(); }); }); }); })

代码非常简单,无需更多解释。此代码使用了mongodb模块,需要首先安装:

rush:bash;"> npm init -y npm i mongodb --save

然后使用node index.js运行即可看到效果:

rush:js;"> Database created! Number of documents inserted: 2 [ { _id: 5b72ab9e3245f169ef5f43d2,id: 1,name: 'reco' },{ _id: 5b72ab9e3245f169ef5f43d3,id: 2,name: 'rita' } ] document deleted

利用高级异步特性

使用Await/Async特性,可以有效的减少代码中的回调地狱现象。同样的功能,可以使用这样的代码:

{ const client = await MongoClient.connect(connectionString,{ useNewUrlParser: true }); const dbo = client.db('todos'); try { var res = await dbo.collection('todo').insertMany( [{id:1,name:"reco"},{id:2,name:"rita"}]); console.log("Number of documents inserted: " + res.insertedCount); var r = await dbo.collection("todo").find().toArray() console.log(r); var myquery = { id: 1 }; var r = await dbo.collection("todo").deleteMany(myquery) console.log("document deleted"); } finally { client.close(); } })().catch(err => console.error(err));

执行此代码输出如下:

Number of documents inserted: 2 [ { _id: 5b72ae8a1c674a6ac1c5aa6e, { _id: 5b72ae8a1c674a6ac1c5aa6f,name: 'rita' } ] document deleted

总结:

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对编程之家的支持

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐