Node js MongoDB简单操作
//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简单操作的更多相关文章
- Node js MySQL简单操作
//win7环境下node要先安装MySQL的相关组件(非安装MySQL数据库),在cmd命令行进入node项目目录后执行以下语句 //npm install mysql var mysql = re ...
- Node.JS + MongoDB技术浅谈
看到一个Node.JS + MongoDB的小样例,分享给大家.魔乐科技软件学院(www.mldnjava.cn)的讲座 Node.JS + MongoDB技术讲座 云计算 +大数据 ...
- node.js+mongodb 爬虫
demo截图: 本demo爬瓜子二手车北京区的数据 (注:需要略懂 node.js / mongodb 不懂也没关系 因为我也不懂啊~~~) 之所以选择爬瓜子二手车网站有两点: 一.网站无需登录,少做 ...
- 8 步搭建 Node.js + MongoDB 项目的自动化持续集成
任何事情超过 90 秒就应该自动化,这是程序员的终极打开方式.Automating shapes smarter future. 这篇文章中,我们通过创建一个 Node.js + MongoDB 项目 ...
- 《Node.js+MongoDB+AngularJS Web开发》读书笔记及联想
总体介绍 <Node.js+MongoDB+AngularJS Web开发>,于2015年6月出版,是一本翻译过来的书,原书名为<Node.js,MongoDB and Angula ...
- AngularJS + Node.js + MongoDB开发
AngularJS + Node.js + MongoDB开发的基于位置的通讯录(by vczero) 一.闲扯 有一天班长说了,同学们希望我开发一个可以共享位置的通讯录,于是自己简单设计了下功能.包 ...
- .Net Core MongoDB 简单操作。
一:MongoDB 简单操作类.这里引用了MongoDB.Driver. using MongoDB.Bson; using MongoDB.Driver; using System; using S ...
- [转]Node.JS使用Sequelize操作MySQL
Sequelize官方文档 https://sequelize.readthedocs.io/en/latest/ 本文转自:https://www.jianshu.com/p/797e10fe23 ...
- node.js + mongodb
node.js + mongodb 这次内容是结合bootstrap把登陆注册做好,还有就是express的中间件等问题. 看这篇博客之前建议先看我上篇写的那篇博客http://www.cnblogs ...
随机推荐
- mysql的char,varchar,text,blob
mysql的char,varchar,text,blob是几个有联系但是有有很大区别的字段类型,这算是mysql的基础吧,可是基础没有学好,恶补一下. 先简单的总结一下: char:定长,最大255个 ...
- AS5600磁编码器开发记录
AS5600使用简介--(程序员版) -----------------本文由"智御电子"提供,同时提供范例教程,以便电子爱好者交流学习.---------------- 前言: ...
- Go搭建一个博客系统
go语言环境就不用多说了,版本肯定越高越好,这里用go1.10 先放着
- 使用bison和yacc制作脚本语言(2)
我们先来想一下语法 一般脚本语言不需要定义类型直接在赋值的时候确定 我们主要考虑一下变量的类型 a = 1; b = 1.1; c = "str"; 一般来讲,我们使用这三种类型, ...
- HDOJ:1533-Going Home(最小费用流)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1533 解题心得: 第一次写最小费用流的题,去hdoj上找了一个入门级题目,建图比较简单,用了spfa和 ...
- 成都Uber优步司机奖励政策(3月17日)
滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...
- 广州Uber优步司机奖励政策(12月21日到12月27日)
滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...
- 【NIS】深入了解NIS
1 简介 NIS( NetworkInformation Service)提供了一个网络黄页的功能,当用户登录系统时,Linux系统会到NIS主机上去寻找用户使用的帐号密码信息加以比对,以提供用户登 ...
- 3329: Xorequ
3329: Xorequ https://www.lydsy.com/JudgeOnline/problem.php?id=3329 分析: 因为a+b = a^b + ((a&b)<& ...
- .net core中Primitives.StringValues 处理
参考地址:https://stackoverflow.com/questions/36297329/primitives-stringvalues-how-to-deserialize-value-t ...