//win7环境下node要先安装MongoDB的相关组件(非安装MongoDB数据库),在cmd命令行进入node项目目录后执行以下语句
//npm install mongodb //创建连接
var MongoClient = require('mongodb').MongoClient;
var url = "mongodb://localhost:27017/testdb"; //链接 testdb 库,不存在则创建
MongoClient.connect(url, function(error, db) {
if (error) throw error;
console.log("testdb 数据库已创建!"); var database = db.db("testdb"); //创建集合(表),已有不会报错
database.createCollection('testtable', function (error, resulat) {
if (error) throw error;
console.log("testtable 集合已创建!");
}); //向testtable表插入文档(条数据)
var testdata = { testfield1: "node mongodb", testfield2: "test val" };
database.collection("testtable").insertOne(testdata, function(error, result) {
if (error) throw error;
console.log("文档插入成功");
}); //向testtable表插入多条数据
var testdatas = [
{ testfield1: 'testval1', testfield2: 'testval2', testfield3: '1'},
{ testfield1: 'testval11', testfield2: 'testval22', testfield3: '2'},
{ testfield1: 'testval111', testfield2: 'testval222', testfield3: '3'}
];
database.collection("testtable").insertMany(testdatas, function(error, result) {
if (error) throw error;
console.log("插入的文档数量为: " + result.insertedCount);
}); //创建并向testtable2表插入多条数据
database.collection("testtable2").insertMany(testdatas, function(error, result) {
if (error) throw error;
console.log("插入的文档数量为: " + result.insertedCount);
}); //更新一条数据
var whereStr = {"testfield1":'testval1'}; // 查询条件
var updateStr = {$set: { "testfield2" : "update_testval2" }};
database.collection("testtable").updateOne(whereStr, updateStr, function(error, result) {
if (error) throw error;
console.log("文档更新成功");
});
//更新多条数据
database.collection("testtable").updateMany(whereStr, updateStr, function(error, result) {
if (error) throw error;
//如果满足条件的文档对应值已经是要修改的值,此处更新条数为0
console.log(result.result.nModified + " 条文档被更新");
}); //删除一条数据
var whereStr = {"testfield1":'testval11'}; // 查询条件
database.collection("testtable").deleteOne(whereStr, function(error, object) {
if (error) throw error;
console.log("文档删除成功");
});
//删除多条数据
var whereStr = {"testfield1":'testval111'}; // 查询条件
database.collection("testtable").deleteMany(whereStr, function(error, object) {
if (error) throw error;
console.log(object.result.n + " 条文档被删除");
}); //查询testtable表全部数据
database.collection("testtable"). find().toArray(function(error, result) { // 返回集合中所有数据
if (error) throw error;
console.log(result);
}); //也可按条件查询查询testtable表 testfield1 字段等于 testval1 的信息
var whereStr = {"testfield1":'testval1'}; // 查询条件
database.collection("testtable"). find(whereStr).toArray(function(error, result) {
if (error) throw error;
console.log(result);
}); //查询结果排序
//先按 testfield2 字段升序排列,再按 testfield3 字段降序排列
var sortStr = { testfield2:1, testfield3: -1 };
database.collection("testtable").find().sort(sortStr).toArray(function(error, result) {
if (error) throw error;
console.log(result);
}); //分页查询
//skip(int) 接受一个数字参数,为返回结果中,跳过指定的条数再显示
//limit(int) 接受一个数字参数,为返回结果中,限制显示的条数
//例子将排序后的结果跳过第 1 条后,显示 2 条内容
var sortStr = { testfield2:1, testfield3: -1 };
database.collection("testtable").find().skip(1).limit(2).toArray(function(error, result) {
if (error) throw error;
console.log(result);
}); //多表连接操作
//mongoDB 不是一个关系型数据库,但可以使用 $lookup 来实现左连接
//首先是查询的主表(左表)
database.collection('testtable').aggregate([
{ $lookup:
{
from: 'testtable2', // 关联的右表
localField: 'testfield1', // 左表要关联的 join 字段
foreignField: 'testfield1', // 右表要关联的 join字段
as: 'newfield' // 新生成字段(类型array)
}
}
], function(error, result) {
if (error) throw error;
//console.log(JSON.stringify(result));
console.log(result);
}); //删除表集合
database.collection("testtable2").drop(function(error, delOK) { // 执行成功 delOK 返回 true,否则返回 false
if (error) throw error;
if (delOK) console.log("集合已删除");
}); db.close();
});

Node js MongoDB简单操作的更多相关文章

  1. Node js MySQL简单操作

    //win7环境下node要先安装MySQL的相关组件(非安装MySQL数据库),在cmd命令行进入node项目目录后执行以下语句 //npm install mysql var mysql = re ...

  2. Node.JS + MongoDB技术浅谈

    看到一个Node.JS + MongoDB的小样例,分享给大家.魔乐科技软件学院(www.mldnjava.cn)的讲座 Node.JS + MongoDB技术讲座          云计算 +大数据 ...

  3. node.js+mongodb 爬虫

    demo截图: 本demo爬瓜子二手车北京区的数据 (注:需要略懂 node.js / mongodb 不懂也没关系 因为我也不懂啊~~~) 之所以选择爬瓜子二手车网站有两点: 一.网站无需登录,少做 ...

  4. 8 步搭建 Node.js + MongoDB 项目的自动化持续集成

    任何事情超过 90 秒就应该自动化,这是程序员的终极打开方式.Automating shapes smarter future. 这篇文章中,我们通过创建一个 Node.js + MongoDB 项目 ...

  5. 《Node.js+MongoDB+AngularJS Web开发》读书笔记及联想

    总体介绍 <Node.js+MongoDB+AngularJS Web开发>,于2015年6月出版,是一本翻译过来的书,原书名为<Node.js,MongoDB and Angula ...

  6. AngularJS + Node.js + MongoDB开发

    AngularJS + Node.js + MongoDB开发的基于位置的通讯录(by vczero) 一.闲扯 有一天班长说了,同学们希望我开发一个可以共享位置的通讯录,于是自己简单设计了下功能.包 ...

  7. .Net Core MongoDB 简单操作。

    一:MongoDB 简单操作类.这里引用了MongoDB.Driver. using MongoDB.Bson; using MongoDB.Driver; using System; using S ...

  8. [转]Node.JS使用Sequelize操作MySQL

    Sequelize官方文档  https://sequelize.readthedocs.io/en/latest/ 本文转自:https://www.jianshu.com/p/797e10fe23 ...

  9. node.js + mongodb

    node.js + mongodb 这次内容是结合bootstrap把登陆注册做好,还有就是express的中间件等问题. 看这篇博客之前建议先看我上篇写的那篇博客http://www.cnblogs ...

随机推荐

  1. Zookeeper -- 本地\完全分布式 搭建

    准备工作 linux软件:Zookeeper-3.4.12.tar.gz 四台centos系统虚拟机,主机名为:s101~s104 一.本地模式搭建(s101上安装) 1.解压软件压缩包:解压到根目录 ...

  2. Python学习手册之 Python 之禅、Python 编程规范和函数参数

    在上一篇文章中,我们介绍了 Python 的正则表达式使用示例,现在我们介绍 Python 之禅. Python 编程规范和函数参数.查看上一篇文章请点击:https://www.cnblogs.co ...

  3. 成都Uber优步司机奖励政策(2月18日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  4. SVN的使用——下载、安装

    今天我们来学习一下如何使用SVN(Subversion) 既然要使用SVN那么我们就先来认识一下SVN.SVN的全名是Subversion,它是一个自由,开源的版本控制系统.在Subversion管理 ...

  5. 「日常训练」Uncle Tom's Inherited Land*(HDU-1507)

    题意与分析 题意是这样的:给你一个\(N\times M\)的图,其中有一些点不能放置\(1\times 2\)大小的矩形,矩形可以横着放可以竖着放,问剩下的格子中,最多能够放多少个矩形. 注意到是\ ...

  6. Windows运行机理——消息与消息队列

    Windows运行机理这系列文章都是来至于<零基础学Qt4编程>——吴迪,个人觉得写得很好,所以进行了搬运和个人加工 Windows程序设计时一种基于消息的时机驱动方式的设计模式,完全不同 ...

  7. Qt-网络与通信-UDP网络通讯

    用户数据报协议是一种简单的轻量级.不可靠.面向数据.无连接的传出层协议,可以应用于在可靠性不是十分重要的场合,如短消息,广播信息等. 例如一下场合 网络数据大多为短消息 拥有大量客户端 对数据安全性无 ...

  8. 180626-Spring之借助Redis设计一个简单访问计数器

    文章链接:https://liuyueyi.github.io/hexblog/2018/06/26/180626-Spring之借助Redis设计一个简单访问计数器/ Spring之借助Redis设 ...

  9. uiautomatorviewer定位App元素

    这个工具是Android SDK自带的, 日常的工作中经常要使用的, 在C:\Android\sdk\tools\bin目录下: 双击之, 请注意, 我一般选择第一个机器人小图标Device Scre ...

  10. jmeter 函数助手

    1.选项,函数助手对话框,打开函数助手 2.使用方法 输入参数,点击生成,可以直接使用(Name of variable in which to store the result (optional) ...