Nodejs开发(2.连接MongoDB)
一、先配置MongoDB
Win10下下载那个安装版,zip版的会报却各种DLL,安装在你希望的路径,实在安装错了,就剪切过来也行(本例E:\mongodb)。
然后是配置启动脚本,就是写一个bat文件,双击即可打开,因为那启动命令实在有点长。
在E:\mongodb\bin下创建一个start.bat文件,写入:
cd E:\mongodb\bin
mongod --dbpath=../data --directoryperdb --logpath=../log.log --logappend
注意要创建好data目录
二、使用Nodejs连接MongoDB
在任意地方都可以写代码,比如我在D盘创建了一个Nodejs文件夹,以后的js文件全部放到里面,
按住shift邮件选择打开命令行,先安装express:(其实这个可以不安装)
npm install express
再安装MongoDB组建:
npm install mongodb
然后打开Sublime Text 3,在刚才的目录下创建一个js文件,并编写代码如下:
var mongodb = require('mongodb'); var server = new mongodb.Server('localhost', 27017, {auto_reconnect:true}); var db = new mongodb.Db('mydb', server, {safe:true}); //连接db db.open(function(err, db){ if(!err){ console.log('connect db'); db.collection('users', {safe:true}, function(err, collection){ if(err){ console.log(err); }else{ var whereStr={"name":"lisi"}; collection.find(whereStr).toArray(function(err,docs){ console.log('find'); console.log(docs); }); collection.findOne(function(err,doc){ console.log('findOne'); console.log(doc); }); } }); }else{ console.log(err); } });
这段代码应该没有什么难以理解的地方。
先给数据库里面插入两条数据:
新建表:db.createCollection('要新建的表名');
db.表名.insert(数据);
查询表中所有数据:db.表名.find();
然后在编辑器中执行control+b即可看到结果:
我给库里插了两条数据:
完整增删改查代码如下:
var mongodb = require('mongodb'); var server = new mongodb.Server('localhost', 27017, {auto_reconnect:true}); var db = new mongodb.Db('mydb', server, {safe:true}); function search(){ db.open(function(err, db){ if(!err){ //console.log(db); console.log('connect db'); db.collection('users', {safe:true}, function(err, collection){ if(err){ console.log(err); }else{ var whereStr={"name":"lisi"}; collection.find(whereStr).toArray(function(err,docs){ console.log('find'); console.log(docs); }); collection.findOne(function(err,doc){ console.log('findOne'); console.log(doc); }); collection.find().toArray(function(err,doc){ console.log('findAll'); console.log(doc); }); } }); }else{ console.log(err); } }); } function change(){ db.open(function(err, db){ if(!err){ //console.log(db); console.log('connect db'); db.collection('users', {safe:true}, function(err, collection){ if(err){ console.log(err); }else{ //var tmp1 = {name:'wangwu',age:13,number:1}; //collection.insert(tmp1,{safe:true},function(err, result){ //console.log(result); //}); //更新数据 collection.update({name:'zhangsan'}, {$set:{age:4}}, {safe:true}, function(err, result){ console.log("update data"); console.log(result); }); // 删除数据 // collection.remove({name:'zhangsan'},{safe:true},function(err,result){ //console.log(result); //}); } }); }else{ console.log(err); } }); } search(); change(); search();