Node.js和MongoDB - MongoJS入门
第一次尝试翻译外国牛人的博文,希望大家喜欢。
本文源码详见:https://github.com/njaulj/mongojs
一点都不夸大的说,近年来node.js和mongodb的确是大放异彩,在web界刮起了一股旋风。
node.js和mongodb不仅仅是一些Geeke的宠物,而是越来越多的大企业也在发展这两门技术,并且起到了杠杆作用,越来越多的用户正在使用这两门利器搭建了,高拓展性、高表现性、高功能性的web程序。
好了,言归正传。
什么是node.js?
node.js是一个立基于Chrome JavaScript Runtime的平台,任何人都可以轻松的用它来部署、开发高速的、高扩展、大吞吐大网络程序。
node.js的两种特性:
1.事件驱动
2.无阻塞的I/O
正是这两种特性使得node.js轻量和高效,在分布式设备上能够轻松的部署实时的数据密集型的程序。
什么是MongoDB?
MongoDB是一个高扩展性、高表现性的开源Nosql 数据库。
本文会从最基础node.js和MongoDB程序开始,首先请确认你已经安装了node.js和MongoDB。
OK,让我们来核实一下你的node.js和mongodb server吧:
$ node -v
$ mongod
介绍一下MongoJS?
MongoJS是一个才华横溢的轻量的Node.js包。你可以通过它使用一个非常类似于MongoDB‘s Javascript shell的API,从而轻松的连接到MongoDB!
安装MongoJS
$ npm install mongojs
OK,我们可以开始搭建我们的JS程序了,并且连接到我们的MongoDB 数据库:
// app.js
var databaseUrl ="mydb";// "username:password@example.com/mydb"
var collections =["users","reports"]
var db =require("mongojs").connect(databaseUrl, collections);
databaseUrl 包含了数据库服务器主机和端口,数据库名字的连接信息。
系统默认的host是localhost,端口是27017.如果你是在开发者环境中的话,databaseUrl只需要包含实际的数据实例名字计科。
collections是一个数组的数据类型。它不是强制的如此,只是为了接近Node.js API让我们更轻松的模拟MongoDb Javascript 客户端。
下面将通过一个例子(给定找到条件来查找所有的女性用户)来查找记录。
// app.js
db.users.find({sex:"female"},function(err, users){
if( err ||!users) console.log("No female users found");
else users.forEach(function(femaleUser){
console.log(femaleUser);
});
});
请注意我们是如何初始化我们的查询语句的。除此之外,我们还通过一个回调函数来管理query出来的结果。
node.js是事件驱动的,通过回调函数能够让你的程序没有阻塞,并且高表现性。
通过运行上面的程序,我们发现 No femail users found。为什么呢?
哈哈,不用大惊小怪,我们还没有往mydb数据库里面添加数据呢?
下面我将通过程序往mydb数据库里面增加几行代码!
// app.js
db.users.save({email:"717010686@qq.com", password:"iLoveMongo", sex:"male"},function(err, saved){
if( err ||!saved ) console.log("User not saved");
else console.log("User saved");
});
db.users.save({email:"18251888949@163.com", password:"iLoveMongo", sex:"female"},function(err, saved){
if( err ||!saved ) console.log("User not saved");
else console.log("User saved");
});
下一个例子是如何更新用户信息:
// app.js
db.users.update({email:"717010686@qq.com"},{$set:{password:"iReallyLoveMongo"}},function(err, updated){
if( err ||!updated ) console.log("User not updated");
else console.log("User updated");
});
OK,让我们来运行app.js吧。
$ node app.js
OK,在这里我们就成功的完成了node.js和MongoDB的入门了。
原著见:http://howtonode.org/node-js-and-mongodb-getting-started-with-mongojs
推广 http://www.keepol.com
Node.js和MongoDB - MongoJS入门的更多相关文章
- 以太坊开发DApp实战教程——用区块链、星际文件系统(IPFS)、Node.js和MongoDB来构建电商平台(一)
第一节 简介 欢迎和我们一起来用以太坊开发构建一个去中心化电商DApp!我们将用区块链.星际文件系统(IPFS).Node.js和MongoDB来构建电商平台类似淘宝的在线电商应用,卖家可以自由地出售 ...
- Node.js 中MongoDB的基本接口操作
Node.js 中MongoDB的基本接口操作 连接数据库 安装mongodb模块 导入mongodb模块 调用connect方法 文档的增删改查操作 插入文档 方法: db.collection(& ...
- MongoDB学习(2)—Node.js与MongoDB的基本连接示例
前提 已经安装了node.js和MongoDB,本文使用的node.js是v0.12.0,MongoDB是3.0.0. 初始化数据 启动MongoDB服务,在test数据库中插入一条实例数据: db. ...
- 使用React、Node.js、MongoDB、Socket.IO开发一个角色投票应用的学习过程(三)
这几篇都是我原来首发在 segmentfault 上的地址:https://segmentfault.com/a/1190000005040834 突然想起来我这个博客冷落了好多年了,也该更新一下,呵 ...
- Node.js与MongoDB的基本连接示例
Node.js与MongoDB的基本连接示例 前提 已经安装了node.js和MongoDB,本文使用的node.js是v0.12.0,MongoDB是3.0.0. 初始化数据 启动MongoDB服务 ...
- [Node.js]连接mongodb
摘要 前面介绍了node.js操作mysql以及redis的内容,这里继续学习操作mongodb的内容. 安装驱动 安装命令 cnpm install mongodb 安装成功 数据库操作 因为mon ...
- node.js+express+mongodb
主要是想用node.js链接mongodb,用的是mongoose.用ejs引擎,扩展到.html比较容易 小例子结构简单,框架清晰. 提交方法 路径 方法 作用 get add post a ...
- Node.js+websocket+mongodb实现即时聊天室
ChatRoom Node.js+websocket+mongodb实现即时聊天室 A,nodejs简介:Node.js是一个可以让javascript运行在服务器端的平台,它可以让javascrip ...
- node.js和MongoDB学习网址
回想我写的node.js和MongoDB的博客,都是菜鸟教程那里的知识,所以我打算不写了,那些都是基础,在项目开发中,我发现单单有那些基础不行,这些基础可以尽快学好,然后学习项目开发过程 下面是两个教 ...
随机推荐
- 文件I/O之sync、fsync和fdatasync函数
传统的UNIX实现在内核中设有缓冲区高速缓存或页面高速缓存,大多数磁盘I/O都通过缓冲进行.当将数据写入文件时,内核通常先将数据复制到其中一个缓冲区中,如果 该缓冲区尚未写满,则并不将其排入输出队列, ...
- (收藏)sokcet编程
C# Socket网络编程精华篇 C#编写高性能网络服务器(源码) .net自动更新组件Ant 客户端服务器通信demo(附源码) 有了WCF,Socket是否已人老珠黄? Socket服务器整体架构 ...
- PHP中的全局变量$_SERVER
1.常用 $_SERVER['PHP_SELF'] #当前正在执行脚本的文件名,与 document root相关.$_SERVER['argv'] #传递给该脚本的参数.$_SERVER['argc ...
- Android NDK STL
相信Android开发者都喜欢用C++编写一些高效的应用,有关Android NDK的C++开发相关知识总结如下: 从Android NDK r5开始支持了STL Port,在这个版本开始 ...
- AppScan在项目中的使用流程
AppScan在项目中的使用流程 http://www.docin.com/p-829022229.html
- 《Mysql 公司职员学习篇》 第二章 小A的惊喜
第二章 小A的惊喜 ---- 认识数据库 吃完饭后,小Y和小A回到了家里,并打开电脑开始学习Mysql. 小Y:"小A,你平时的Excell文件很多的情况下,怎么样存放Exce ...
- (转)战斗bug技巧全攻略
原文地址:http://www.cnblogs.com/manuosex/p/3736077.html 程序员不是有一幅这样的对联吗 上联:一个项目两部电脑三餐盒饭只为四千工资搞得五脏俱损六神无主仍然 ...
- PeopleReady 是什么系统?其中文为全员就绪
PeopleReady 中文:全员就绪. 顾名思义: 一句话:PeopleReady 就是能使人快速Ready的系统. 稍长一句话:就是能使大家快速Ready(经验+知识)的系统. 详细的来说:通过积 ...
- Apache Shiro 使用手册
http://kdboy.iteye.com/blog/1154644 (一)Shiro架构介绍 一.什么是Shiro Apache Shiro是一个强大易用的Java安全框架,提供了认证.授权.加 ...
- SQLServer数据操作(建库、建表以及数据的增删查改)
SQLSever数据操作 一.建立数据库: create database DB ---数据库名称 ( name=data1 --文件名, ...