MongoDB采用了MongoDB Node.js驱动程序作为标准。

1.安装MongoDB驱动

npm install mongoDB
npm install mongoose

require('mongodb')可以访问mongodb模块

2.从Node.js连接到MongoDB

可以通过打开到MongoDB服务器的连接开始从Node.js应用程序访问MongoDB.

连接用来:创建,更新存取MongoDB数据库中的接口

访问MongoDB最佳方法:通过mongodb模块中的MongoClient类。

1)创建MongoClient对象的一个实例,通过该对象创建和管理MongoDB的连接。

2)使用连接字符串进行连接

2.1.写入关注

连接和更新MongoDB服务器上的数据前,要决定连接上实现什么级别的写入关注。

write concern 指的是:在报告写操作成功的时候,MongoDB连接提供的保证

2.2.了解Server对象

MongoClient连接利用了在后台的Server对象。这个对象定义了MongoDB驱动程序应该怎样连接到服务器。

Server对象包含:创建连接时所用的主机,端口,池的大小,以及套接字的超时值的信息。

Server对象选项:readPreference ssl poolSize socketOptions auto_reconnect

2.3.通过client对象连接到MongoDB

使用MongoClient对象连接到MongoDB涉及创建客户端的一个实例,打开到数据库的连接,以及如果需要,验证到数据库,然后根据需要处理注销和关闭。

MongoClient(Server,options)

Server为第一个参数,第二个参数规定了数据库的连接选项

var client=new MongoClient(new Server('localhost',27017,{poolSize:5}),retryMiliSeconds:500);

一旦创建了MongoClient,可以通过open(callback)打开到服务器的MongoDB数据库的连接。

(新版本废除了client.open()方法)

client.open(function(err,client){...})

连接到特定的数据库,需要在client对象上使用db(databasename)方法创建数据库实例。可以使用数据库连接选项,创建可用于访问特定数据库的集合中的db对象实例。如果启用了身份验证,在尝试访问前:

db.authenticate(username,password,callback)验证到数据库

var db=client.db("testDB");
db.authenticate("dbadmin","test",function(err,results){...})

要注销数据库,使用对象上的logout()方法。将关闭到数据库的连接

db.logout();

要关闭到MongoDB的连接,在客户端上调用close()

client.close()

2.4.通过连接字符串连接到MongoDB

可以使用一个简单的连接字符串创建,打开,并验证到数据库的连接。

用于连接到数据库的Server和MongoClient选项在后台生成。

MongoClient.connect(connString,options,callback)

connString字符串的语法如下:

mongodb://username:password@host:port/database?options

options可以包含db,server,rplSet和mongos属性的一个对象  

3.在MongoDB Node.js驱动程序中的对象

MongoDB Node.js驱动程序使用了大量的结构化对象与数据库进行交互。  

Db对象:提供对数据库的访问。(连接,添加用户,访问集合) 数据库创建,Db对象被创建

Admin对象:对MongoDB数据库执行管理职能。专门代表到admin数据库的连接

Collection对象:数据库的集合。可以使用Collection对象访问集合中的条目,添加文档,查询文档。。

4.访问和操作数据库

提供了从Node.js应用程序创建并管理数据库的能力。

列出数据库

var MongoClient=require('mongodb').

4.1.列出数据库  

要列出一个系统中的数据库,需要在Admin对象上使用listDatabases()

数据库列表在回调函数的第二个参数中返回,并且是数据库对象的一个简单的数组。

var MongoClient=require('mongodb').MongoClient;
MongoClient.connect("mongodb://localhost/admin",function(err,db){
var admainDB=db.admin();
adminDB.listDatabases(function(err,databases){
console.log("before add database list: ");
console.log(database);
})
})

4.2.创建数据库

MongoClient连接Db对象上的Db()方法创建一个新的Db对象实例。调用Db对象实例上的createCollection()来创建数据库。

新版直接用 var newDB=db.db("newDB");

4.3.删除数据库

Db实例的dropDatabase()方法删除  

var MongoClient=require('mongodb').MongoClient;
MongoClient.connect("mongodb://localhost/",function(err,db){
var adminDB=db.admin();
adminDB.listDatabases(function(err,databases){
console.log("before add database list:");
console.log(databases);
});
var newDB=db.db("newDB");
newDB.createCollection("newCollection",function(err,collection){
if(!err){
console.log("new database and collection created");
adminDB.listDatabases(function(err,databases){
console.log("after add database list:");
console.log(databases);
db.db("newDB").dropDatabase(function(err,results){
if(!err){
console.log("database dropped");
setTimeout(function(){
adminDB.listDatabases(function(err,results){
var found=false;
for(var i=0;i<results.databases.length;i++){
if(results.databases[i].name=="newDB")
found=true;
}
if(!found){
console.log('after delete database list: ');
console.log(results);
}
db.close();
})
},1500)
}
})
})
}
})
})

4.5.获取MongoDB服务器的状态

admin对象的另一大特性,具有获取有关MongoDB的服务器状态信息的能力。

主机名,版本,运行时间,打开的游标

Admin对象的serverStatus()方法

  

 

  

  

  

  

1.从Node.js链接到MongoDB的更多相关文章

  1. React+Node.js+Express+mongoskin+MongoDB

    首发:个人博客,更新&纠错&回复 采用React + Node.js + Express + mongoskin + MongoDB技术开发的一个示例,演示地址在这里,项目源码在这里. ...

  2. node.js高效操作mongodb

    node.js高效操作mongodb Mongoose库简而言之就是在node环境中操作MongoDB数据库的一种便捷的封装,一种对象模型工具,类似ORM,Mongoose将数据库中的数据转换为Jav ...

  3. Node.js:连接 MongoDB

    ylbtech-Node.js:连接 MongoDB 1.返回顶部 1. Node.js 连接 MongoDB MongoDB是一种文档导向数据库管理系统,由C++撰写而成. 本章节我们将为大家介绍如 ...

  4. mongoose - 让node.js高效操作mongodb

    Mongoose库简而言之就是在node环境中操作MongoDB数据库的一种便捷的封装,一种对象模型工具,类似ORM,Mongoose将数据库中的数据转换为JavaScript对象以供你在应用中使用. ...

  5. [译]简单得不得了的教程-一步一步用 NODE.JS, EXPRESS, JADE, MONGODB 搭建一个网站

    原文: http://cwbuecheler.com/web/tutorials/2013/node-express-mongo/ 原文的源代码在此 太多的教程教你些一个Hello, World!了, ...

  6. [MEAN Stack] First API -- 1. with Node.js, Express and MongoDB

    Learn how to import data into your MongoDB and then use Express to serve a simple Node.js API. Impor ...

  7. [转] Creating a Simple RESTful Web App with Node.js, Express, and MongoDB

    You can find/fork the sample project on GitHub Hey! This and all my other tutorials will soon be mov ...

  8. [js高手之路]Node.js+jade+express+mongodb+mongoose+promise实现todolist

    promise主要是用来解决异步回调问题,其实还有好几种比promise更好的方案,后面再说,这节,我们先用promise来改造下,我以前写的一篇文章[js高手之路]javascript腾讯面试题学习 ...

  9. node.js(express)连接mongoDB入门指导

    一.写在前面 人人都想成为全栈码农,作为一个web前端开发人员,通往全栈的简洁之路,貌似就是node.js了.前段时间学习了node.js,来谈谈新手如何快速的搭建自己的web服务,开启全栈之路. 二 ...

随机推荐

  1. IIS短文件名暴力枚举漏洞利用脚本

    import sys import httplib import urlparse import threading import Queue import time class Scanner(): ...

  2. Java实现数组排序

    package com.souvc.hibernate.exp; public class MySort { /** * 方法名:main</br> * 详述:Java实现数组排序 < ...

  3. 重写Oracle的wm_concat函数,自定义分隔符、排序

    oracle中,wm_concat函数是一个聚合函数,和mysql中的group_concat函数类似,不过group_concat函数比较强大,可以定义分隔符和排序,当然所谓强大是相对的,这里假使我 ...

  4. 快速部署tomcat项目的Shell脚本

    为了做集群测试,在每台机器上装了3个tomcat,每次发布项目的时候都要反复敲一些命令,重启tomcat之前先检查tomcat进程有没有停掉,没有还要手动kill该进程. 发布次数多了,操作就比较繁琐 ...

  5. ReactNative官方中文文档0.21

    整理了一份ReactNative0.21中文文档,提供给需要的reactnative爱好者.ReactNative0.21中文文档.chm  百度盘下载:ReactNative0.21中文文档 来源: ...

  6. 谈谈你对 Struts 2 的理解

    谈谈你对Struts的理解. struts是一个按MVC模式设计的Web层框架,其实它就是一个大大的servlet,这个Servlet名为ActionServlet,或是ActionServlet的子 ...

  7. c#资料

    类型系统: 运行模型: 整型: 浮点: 财务: 布尔: 字符: 引用类型: Console控制字符: {序号,空间:控制字符与精度} 如:{0,3:C2} {空间:#.00} 其中,#表示该位置如果有 ...

  8. DbUtility v3

    DbUtility v3 历史 七年前,也就是2007年,我在博客园写了一篇博文,开源并发布了恐怕是我第一个开源项目,DbUtility.其设计的初衷就是为了简化ADO.NET繁琐的数据库访问过程,提 ...

  9. oop五大设计原则

    一:单一职责原则单一职责有2个含义,一个是避免相同的职责分散到不同的类中,另一个是避免一个类承担太多职责.减少类的耦合,提高类的复用性. 二:接口隔离原则表明客户端不应该被强迫实现一些他们不会使用的接 ...

  10. RGW/SWIFT对象存储性能测试工具--COSBench安装

    Cosbench是Intel的开源云存储性能测试软件,COSBench目前已经广泛使用与云存储测试,并作为云存储的基准测试工具使用 https://github.com/intel-cloud/cos ...