node - MongoDB数据库
mongod
安装配置
在
Mongodb
官网下载最新版本的Mongodb下载地址下载
msi
的window
安装包,可以装到C盘或者D盘目录下配置
由于我是安装在D盘的环境下
D:\Program Files (x86)\MongoDB\Server\3.2\bin
所以在bin文件夹下找到mongod.exe命令,然后通过管理员执行
mongod --dbpath x路径x
,路径可以是任何地方,我这里选择在D盘的MongoDB目录下,当然路径不要包含特殊的字符串,比如Program Files (x86)
也不行mongod --dbpath D:\mongodb\data\db
命令
mongo 进入mongo环境
show dbs :查看当前的数据库列表
show collections:查看当前库当中的集合列表
use 数据库名 : 使用指定的库
db:查看当前所在的数据库
db.dropDatabase:删除当前的数据库
增
use 数据库名: 新增数据库
db.集合名,insert({name:"zxr"}) //新增一个集合里面的文档{name:"zxr"}
db.score.insert({userName:"xiaozhang"}):的score集合当中增加了一个文档
mongoimport --db scoreList --collection score --file E:\1924\Lession04\data --drop
--db:指定数据库
--collection:指定集合
--file:指定导入的文件
--drop:可省略。如果使用该属性则是覆盖,否则是追加。
删 remove
db.data.remove({}) : 删除所有文档
db.data.remove({name:"997"}) : 删除name:"997"
db.data.remove({age:{$gte:16}},{justOne:true}):删除年龄大于等于16的符合条件的第一个文档。
改 update
db.data.update({name:"zhangsan"},{age:10}) 完整替换 把{name:"zhangsan"}的文档替换成{age:10}的文档
db.data.update({userName:"王五"},{$set:{sex:"女"}}) :将名字为王五的性别修改为女
db.data.update({sex:"男"},{$set:{age:18}}):只能修改一条。
db.data.update({sex:"女"},{$set:{age:16}},{multi:true}):更改多条。
db.data.update({userName:"二哈"},{$inc:{age:1}}):根据条件,将年龄加1
查 find
db.集合名.find() : 查找当前库下集合名的文档列表
db.集合名.count():指定集合文档数量
db.集合名.find().count() : 根据条件查找数量
db.集合名,find({name:"zxr"}) :查找name:zxr的数据
db.集合名.find({sex:"女"})):查找性别为女的集合。
db.集合名.find({userName:/常/}):模糊查找。查找名字当中包含常
db.集合名.find({"score.yuwen":2}):查找语文成绩为2的文档
db.集合名.find({age:{$gt:12}}):查找年龄大于12
$gt:大于
$gte:大于等于
$lt:小于
$lte:小于等于
$ne
db.集合名.find({age:{$ne:12},sex:"女"}):多条件,年龄不等于12,性别为女
或
db.集合名.find({$or:[{sex:"女"},{age:12}]}):查找性别为女,或年龄为12的记录
db.集合名.find().skip(2):跳指指定的文档数(
跳过前两行文档)
db.集合名.find().limit(3):取指定的文档数(取前三行文档)
db.集合名.find().sort({age:-1}):按照年龄的倒序。1正序,-1倒序
db.集合名.find().sort({age:-1,"score.yuwen":1}):按照年龄的倒序,如果年龄相同,按照语文的正序
分页
已知:
1、pageIndex:指定的页数
2、count:文档数量
3、pageSum:总页数 pageSum = Math.ceil(count/pageNum)
4、pageNum:每页显示的条数
求:
每页要显示的内容。
问:总条数9,每页2条,每一页的内容如何求
skip = (pageIndex-1)*pageNum;
1、 db.score.find().sort({age:-1}).skip(0).limit(2)
2、 db.score.find().sort({age:-1}).skip(2).limit(2)
3、 db.score.find().sort({age:-1}).skip(4).limit(2)
4、 db.score.find().sort({age:-1}).skip(6).limit(2)
4、 db.score.find().sort({age:-1}).skip(8).limit(2)
node 操作数据库
初始化
npm init -y
下载mongodb
npm install mongodb -S
cnpm install mongodb -S
引入
const mongodb = require("mongodb");
const mongoClient = mongodb.MongoClient;// 端,可以连接数据库。从而实现对数据的操作
mongoClient.connect("mongodb://127.0.0.1:27017",function(err,client){
client.db();// 指定你要操作的数据库
})
挂载数据库
创建一个文件夹 mongo
mongod --dbpath
挂载将cmd最小化
-
结果:It looks like you are trying to access MongoDB over HTTP on the native driver port.
1.连接数据库
var MongoClient = require('mongodb').MongoClient;
//结尾是选择数据库名
var DB_CONN_STR = 'mongodb://localhost:27017/wscats';
MongoClient.connect(DB_CONN_STR, function(err, db) {
console.log("连接成功!");
});
2.查询数据
注意查询回来的结果需要toArray来遍历处理
var MongoClient = require('mongodb').MongoClient;
var DB_CONN_STR = 'mongodb://localhost:27017/wscats';
MongoClient.connect(DB_CONN_STR, function(err, db) {
console.log("连接成功!");
//选中age集合,并用find方法把结果集拿回来进行处理
db.collection("age").find({title: "cba"}).toArray(function(err, result) {
if (err) {
console.log('Error:' + err);
return;
}
console.log(result);
});
});
经过测试,读取大于100条的时候会出现报错官网解释,可以尝试用forEach
代替
db.collection('pokemon').find({})
.forEach(function(item){
console.log(item)
})
查询ID
查询自动生成的ObjectId
var ObjectId = require('mongodb').ObjectId;
let _id = ObjectId("5bcae50ed1f2c2f5e4e1a76a");
db.collection('xxx').find({
"_id": _id
}).forEach(function (item) {
console.log(item)
})
3.插入数据
insert函数第一个参数是需要插入的值(可以一个也可以多个),第二个参数是接受一个回调函数,当值插入成功后回返回插入值得一些关键信息,比如_id
var MongoClient = require('mongodb').MongoClient;
var DB_CONN_STR = 'mongodb://localhost:27017/wscats';
MongoClient.connect(DB_CONN_STR, function(err, db) {
console.log("连接成功!");
const db = client.db("demo");
db.collection("age").insert([
{
title: "插入的值A"
}, {
title: "插入的值B"
}
], function(err, result) {
if (err) {
console.log('Error:' + err);
return;
}
console.log(result)
})
});
4.更新数据
注意如果不加$set就是完全替换原来的那份(没有设置的属性值将会丢失),加上$set则只是更新对应的属性值,其余不做改变
var MongoClient = require('mongodb').MongoClient;
var DB_CONN_STR = 'mongodb://localhost:27017/wscats';
MongoClient.connect(DB_CONN_STR, function(err, db) {
console.log("连接成功!");
db.collection("age").update({
"_id": 1
}, {
$set: {
title: "你好,世界",
skill: "js"
}
}, function(err, result) {
if (err) {
console.log('Error:' + err);
return;
}
//console.log(result);
});
});
5.删除数据
var MongoClient = require('mongodb').MongoClient;
var DB_CONN_STR = 'mongodb://localhost:27017/wscats';
MongoClient.connect(DB_CONN_STR, function(err, db) {
console.log("连接成功!");
db.collection("age").remove({
"_id": 1
}, function(err, result) {
if (err) {
console.log('Error:' + err);
return;
}
//console.log(result);
//关闭数据库
db.close();
});
});
6.关闭数据库
db.close();
node - MongoDB数据库的更多相关文章
- Node使用Mongoose操作MongoDB数据库——增删改查的实现
当初刚出社会时就规划了下自己的职业生涯:先成为一名优秀的前端工程师,再成为一名全栈工程师(精通前端开发.后台开发和客户端开发),最后成为一名优秀的系统架构师.转眼间已经工作快三年,是时候迈出关键性的一 ...
- node.js零基础详细教程(6):mongodb数据库操作
第六章 建议学习时间4小时 课程共10章 学习方式:详细阅读,并手动实现相关代码 学习目标:此教程将教会大家 安装Node.搭建服务器.express.mysql.mongodb.编写后台业务逻辑. ...
- 使用免费 mongodb数据库 + 免费node.js服务器搭建小程序接口
由于微信的小程序只支持不带端口的域名接口,不支持IP地址和接口,所以我们需要映射到80端口并绑定备案过的域名才能被微信小程序访问到.简单点就是接口需要 https 协议才行,找了许久的免费的数据库与n ...
- vue+node+mongoDB 火车票H5(六)---城市列表保存到MongoDB数据库并且启用node.js服务
把车站列表保存到数据库,并且从本地创建服务 node.js创建httpserver 1.搭建基于express的运行环境 全局安装express-gengerator cnpm install -g ...
- node.js零基础详细教程(6):mongodb数据库操作 以及导入导出
第六章 建议学习时间4小时 课程共10章 学习方式:详细阅读,并手动实现相关代码 学习目标:此教程将教会大家 安装Node.搭建服务器.express.mysql.mongodb.编写后台业务逻辑. ...
- Node.js+Express+MongoDB数据库实现网页注册登入功能
通过 Node.js + Express + MongoDB 实现网页注册账号 和 登入账号的功能 项目准备: 1: 事先准备好项目的页面 (首页页面 index.html)(登入页面 login.h ...
- node.js连接MongoDB数据库,db.collection is not a function完美解决
解决方法一. mongodb数据库版本回退: 这个错误是出在mongodb的库中,在nodejs里的写法和命令行中的写法不一样,3.0的api已经更新和以前的版本不不一样,我们在npm中没指定版本号的 ...
- 2. node接口搭建--连接MongoDB数据库 (参考https://blog.csdn.net/ncepu_Chen/article/details/98725104#_337)
1.使用mongoose连接MongoDB数据库 npm install mongoose 2.新建文件夹config存放数据库地址 3.安装MongoDB
- 线上mongodb数据库mLab使用总结
最近在CNode社区看到有人分享了免费的线上mongodb数据库(容量500M),今天去注册了一下,成功的将线下数据库替换掉了,现在就说一下它的使用和配置需要注意的地方: mLab是一款免费的在线mo ...
随机推荐
- GPU图形绘制管线简介
(阅读GPU+编程与CG+语言之阳春白雪下里巴人所得总结) GPU图形绘制管线是描述GPU渲染(把三维世界显示为屏幕上的二维图像)的流程,主要分为三个主要阶段应用程序阶段.几何阶段.光栅阶段. 1.应 ...
- python循环语句(while和for)
循环语句分成两种,while循环 和 for循环 作用:可以使指定的代码块重复指定的次数 while循环: # 语法: # while 条件表达式 : # 代码块 # else : # 代码块 # 执 ...
- 最短路变形题目 HDU多校7
Mr.Quin love fishes so much and Mr.Quin’s city has a nautical system,consisiting of N ports and M sh ...
- proxy应用场景
//场景一:可以修改对象的值let o = { name: 'xiaoming', price: 190 } let d = new Proxy(o,{ get (target,key){ if(ke ...
- Ubuntu阿里镜像
ubuntu 14.04: http://mirrors.aliyun.com/ubuntu-releases/14.04/ ubuntu 16.04: http://mirrors.aliyun.c ...
- 为BlueLake主题增加自定义icon图标
一.前言 hexo 的 Bluelake 主题是我一直在用的,简单大方,很喜欢.但最近有了添加自定义 icon 图标的需求,比如,添加 "地址"."扫一扫".& ...
- 《ASP.NET Core 高性能系列》关于性能的闲聊
一.通常的性能问题类型 让我们一起看看那些公共的性能问题,看看他们是或者不是.我们将了解到为什么我们常常在开发期间会错过这些问题.我们也会看看当我们考虑性能时语言的选择.延迟.带宽.计算等因素. 二. ...
- exp2:// 一次存储型XSS从易到难的挖掘过程
一日在某站点发现一个找茬活动,感觉是另类的src就参与了一下.就发生了这次有趣的XSS测试过程. 0×00 开始 (注意1)XSS不仅存在于页面上直观所在的位置,所有用户输入的信息都有可能通过不同形式 ...
- Hbase与Maven工程的Spring配置笔记
1.HBase基本操作 hbase shell: 连接到正在运行的HBase实例 help: 显示一些基本的使用信息以及命令示例. 需要注意的是: 表名, 行, 列都必须使用引号括起来 create ...
- Java基础系列1:Java基本类型与封装类型
Java基础系列1:Java基本类型与封装类型 当初学习计算机的时候,教科书中对程序的定义是:程序=数据结构+算法,Java基础系列第一篇就聊聊Java中的数据类型. 本篇聊Java数据类型主要包括两 ...