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 ...
随机推荐
- python爬虫#数据存储#JSON/CSV/MYSQL/MongoDB/
Json数据处理 JSON支持数据格式: 对象(字典).使用花括号. 数组(列表).使用方括号. 整形.浮点型.布尔类型还有null类型. 字符串类型(字符串必须要用双引号,不能用单引号). 多个数据 ...
- 『Linux基础 - 5 』Linux常用命令(2)
这篇笔记的只要知识点: (1)ls查看文件信息,列表中每个字符所代表的含义 (2) 使用通配符匹配文件 (3) chmod命令:修改文件或目录权限 (4) 与用户相关命令(who.su.exit.pa ...
- python学习笔记:第7天 深浅拷贝
目录 1. 基础数据类型补充 2. set集合 3. 深浅拷贝 1. 基础数据类型补充 (1)join方法 join方法是把一个列表中的数据进行拼接,拼接成字符串(与split方法相反,split方法 ...
- Python 1.1数字与字符基础
一. 基础数字操作 1.加减乘除以及内置函数: min(), max(), sum(), abs(), len() math库: math.pi math.e, math.si ...
- 20145234黄斐《Java程序设计》第三周学习总结
教材学习内容总结 类与对象 定义:对象,与过程相对. Java中变量有2种类型,一个是基本类型,另一个则是类类型.基本类型在之前学过,本次学习类类型.使用Java撰写程序几乎都是在使用对象,要产生对象 ...
- 北京Uber优步司机奖励政策(1月19日)
滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...
- Redis系列二 Redis数据库介绍
1.SELECT命令 通过查看配置文件可以知道Redis默认有17个库,从0-16. 默认是在0号库.选择库使用SELECT <dbid>命令.例如选择0号库 SELECT 0 2.DB ...
- WeTest功能优化第1期:截图960px,云真机映射功能了解
第1期功能优化目录 [全线产品测试截图优化]安卓机型测试截图分辨率上升至960px [云真机新增Android 9]最新安卓系统,等你pick [云真机新增键盘映射功能]电脑键盘码字,云真机同步显示 ...
- 破解IDEA注册码,设置 license server一直有效不过期
破解的详细过程: 1.从下面地址下载一个jar包,名称是 JetbrainsCrack-2.10-release-enc.jar 下载地址是http://idea.lanyus.com/,进去之后点 ...
- lesson 22 by heart
lesson 22 by heart on end = continuously 连续不断地 know/learn sth by heart 记忆sth falter: speak hesitantl ...