Practical Node.js (2018版) 第5章:数据库 使用MongoDB和Mongoose,或者node.js的native驱动。
Persistence with MongoDB and Mongoose
https://github.com/azat-co/practicalnode/blob/master/chapter5/chapter5.md
学习mongodb的官方网站:
https://university.mongodb.com/ (免费课程,-> study guide,-> exam)
https://docs.mongodb.com/manual/tutorial/getting-started/
Mongodb node.js driver3.x版本的 guide:
http://mongodb.github.io/node-mongodb-native/3.1/upgrade-migration/main/
⚠️:本书上的案例使用的是2.2版本的代码,如open命令,在3.0驱动版已经删除。
Mongoose :https://mongoosejs.com/ (17000✨)
写MongoDb Validation, casting和business logic boilerplate是很烦人的drag/boring。
因此使用mongoose代替。
我真的喜欢使用MongoDB with Node。因为这个数据库有JavaScript interface, 并使用JSON-like data structure。
MongoDB是一种NoSQL database。
NoSQL databases (DBs), also called non-relational databases非关系型数据库。
more horizontally scalable,在横向上有更多的扩展性
better suited for distributed systems than traditional SQL,比传统的SQL更适合分布式的系统。
NoSQL DBs内置方法让数据复制和自定义查询语法。这被叫做反规范化denormalization.
NoSQL databases deal routinely with larger data sizes than traditional ones.
通常非关系数据库处理比传统关系数据库更大的数据。
关键的区别:
NoSQL DBs是没有schema的。
没有table,仅仅是一个有IDS的简单store。
大量数据类型是不储存在数据库(没有更多的ALTER table 查询); 它们被移动到app,或者object-relational mapping (ORM) levels--我们的案例,移动到Node.js代码。
作者说:
这些NoSQL最棒的优点!我可以快速地prototype prototyping和iterate (more git pushes!)
一旦我或多或少的完成,我能执行 implement schema和validation in Node.
This workflow allows me to not waste time early in the project lifecycle
while still having the security at a more mature stage.
这种工作流程,让我不会在工程的早期浪费时间,同时在更成熟的阶段仍有安全。?
MongoDB
文档储存的非关系型数据库。
与之对比的是key-value类型的数据库如Redis, 以及wide-column store NoSQL databases。
NoSQL DBs汇总:http://nosql-database.org/
MongoDB是最成熟mature,dependable的NoSQL数据库。
另外,MongoDB有一个JavaScript交互interface!这非常棒!
因为现在无需在前端(browser JavaScript)和后端(Node.js)之间来回切换switch context,和数据库。
这是我最喜欢的功能!
开发MongoDB的公司是一个工业的领导者,提供了学习MongoDB的在线网站 (https://university.mongodb.com).
https://docs.mongodb.com/manual/tutorial/getting-started/
准备开始MongoBD和Node.js , 本章将讲如下章节:
- Easy and proper installation of MongoDB
- How to run the Mongo server
- Data manipulation from the Mongo console
- MongoDB shell in detail
- Minimalistic native MongoDB driver for Node.js example
- Main Mongoskin methods
- Project: Storing Blog data in MongoDB with Mongoskin
Easy and Proper Installation of MongoDB
macOS使用HomeBrew安装。✅
$ brew install mongodb
或者从官网下载文件并配置它。http://www.mongodb.org/downloads
其他安装方式见本文后续说明和连接。
可选:
如果想在你的系统的任何位置使用MongoDB命令, 需要把mongoDB path增加到$PATH变量。
对应macOS,你需要open-system path file, 它在/etc/paths:
$ sudo vi /etc/paths
然后,在/etc/paths文件内增加下面的代码:
/usr/local/mongodb/bin
创建一个data文件夹;默认 MongoDB使用根目录的/data/db。
//创建文件夹
$ sudo mkdir -p /data/db
//改变group和owner
$ sudo chown `id -u` /data/db
这个数据文件夹是你的本地数据库实例的存放位置~,它存放所有databases, documents,和on-all data.
如果你想储存数据在其他地方,可以指定path, 当你登陆你的database实例时,使用--dbpath选项给mongod命令.
各种安装方法官网:
How to Run the Mongo Server
使用mongod命令来启动Mongo server
如果你手动安装,并没有连接位置到PATH, 去到你解包MongoDB的这个folder。那里有个bin文件夹。
输入:
$ ./bin/mongod
如果你像大多数开发者一样,喜欢在你的电脑任意位置输入mongod, 我猜测你把MongoDB bin文件夹放入了你的PATH环境变量中。所以如果你为MongoDB location增加$PATH, 就直接输入:
//任意位置
$ mongod
⚠️注意,在增加一个新的path给$PATH变量需要重启terminal window。
当teminal上出现
waiting for connections on port 27017
意味着MongoDB数据库server正在运行!Congratulations!
默认它监听 http://localhost:27017。
This is the host and port for the scripts and applications to access MongoDB.
In our Node.js code, we use 27017 for for the database and port 3000 for the server.
Data Manipulation from the Mongo Console
和Node.js REPL类似,MongoDB也有一个console/shell,作为database server实例的客户端。
这意味着,保持一个terminal window跑server,再开启一个tab/window用于console。
开启console的命令:
$ ./bin/mongo //或mongo
当你成功地连接到数据库实例,之后你应该看到这些:
MongoDB shell version: 4.0.5
connecting to: test
看到光标>, 现在你在一个不同的环境内而不是zsh或bash。
你不能再执行shell命令了,所以不要使用node server.js或者mkdir。
但是你可以使用JavaScript,Node.js和一些特定的MongoDB代码。
例如,执行下面的命令,来保存一个document{a: 1}, 然后查询这个集合,来看看这个新创建的document:
> db.test.save({a: 1})
WriteResult({ "nInserted" : 1 })
> db.test.find()
{ "_id" : ObjectId("5c3c68cb8126284dea64ff02"), "a" : 1 }
命令find(), save()就是字面的意思。
你需要在它们前面加上db.COLLECTION_NAME, 用你自己的名字替代COLLECTION_NAME
⚠️在masOS,使用control + C关闭process,
下章讨论最重要的MongoDB console commands:
MongoDB Console in Detail
MongoDB控制台语法是JavaScript。这非常棒!
最后一件我们想要的是学习一个新的复制的语言,如SQL。
db.test.find() //db是类名 //test是collection name //find是方法名
常用的MongoDB console(shell) commands:
- help: 打印可以使用的命令
- show dbs: 打印数据库名字, prints the names of the databases on the database server to which the console is connected。默认是localhost:27017; 但是如果传递参数到mongo, 我们可以连接到任何远程实例remote instance。
admin 0.000GB
config 0.000GB
local 0.000GB
test 0.000GB- use db_name: switches to db_name
- show collections: 打印所选的数据库中的collections的名单。
- db.collection_name.find(query), 找到所有匹配查询的items。
- db.collection_name.findOne(query)
- ⚠️:find方法是Read Operations(CURD)
- db.collection_name.insert(document) 除此之外还有insertOne, insertMany方法。
- ⚠️:insert是create operations创建操作符
- db.collection_name.save(docuemnt)
- .
- db.collection_name.update(query, {$set: data}): 先找到匹配query条件的items,然后更新。
- ⚠️:update是Update Operations
- db.collection_name.remove(query): 移除所有匹配query的items。
- deleteOne(query), deleteMany(query)是3.0以后的版本的方法。
- printjson(document); 打印变量document的值。
> db.messages.save({a: 1})
> var a = db.messages.findOne()
//a的值是{ "_id" : ObjectId("5c3c8112cdb3fb6e147fb614"), "a" : 1 }
> printjson(a)
> a.text = "hi"
> printjson(a)
> db.messages.save(a)
save()方法有2种工作形式:
如果有_id, 这个document会被更新,无论什么新属性被传入到save()。
> db.messages.save(a)
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.messages.find()
{ "_id" : ObjectId("5c3c8112cdb3fb6e147fb614"), "a" : 1, "text" : "hi" }
如果没有_id,将插入一个新document并创建一个新的document ID
Practical Node.js (2018版) 第5章:数据库 使用MongoDB和Mongoose,或者node.js的native驱动。的更多相关文章
- Practical Node.js (2018版) 第7章:Boosting Node.js and Mongoose
参考:博客 https://www.cnblogs.com/chentianwei/p/10268346.html 参考: mongoose官网(https://mongoosejs.com/docs ...
- Practical Node.js (2018版) 第9章: 使用WebSocket建立实时程序,原生的WebSocket使用介绍,Socket.IO的基本使用介绍。
Real-Time Apps with WebSocket, Socket.IO, and DerbyJS 实时程序的使用变得越来越广泛,如传统的交易,游戏,社交,开发工具DevOps tools, ...
- Practical Node.js (2018版) 第10章:Getting Node.js Apps Production Ready
Getting Node.js Apps Production Ready 部署程序需要知道的方面: Environment variables Express.js in production So ...
- Practical Node.js (2018版) 第3章:测试/Mocha.js, Chai.js, Expect.js
TDD and BDD for Node.js with Mocha TDD测试驱动开发.自动测试代码. BDD: behavior-driven development行为驱动开发,基于TDD.一种 ...
- Practical Node.js (2018版) 第8章:Building Node.js REST API Servers
Building Node.js REST API Servers with Express.js and Hapi Modern-day web developers use an architec ...
- Practical Node.js (2018版) 第4章: 模版引擎
Template Engines: Pug and Handlebars 一个模版引擎是一个库或框架.它用一些rules/languages来解释data和渲染views. web app中,view ...
- Practical Node.js (2018版) 13章, Node HTTP/2 Servers
新增的章节. If you are not using HTTP/2, then you are losing out on big improvements. HTTP/2相比http/1有很大的区 ...
- Practical Node.js (2018版) 14章, async code in Node
Asynchronous Code in Node 历史上,Node开发者只能用回调和事件emitters. 现在可以使用一些异步的语法: async module Promises Async/aw ...
- Practical Node.js摘录(2018版)第1,2章。
大神的node书,免费 视频:https://node.university/courses/short-lectures/lectures/3949510 另一本书:全栈JavaScript,学习b ...
随机推荐
- Mac10.13 telnet不能用的解决方法
telnet在Mac 10.13上不能用了 Restore的方法 brew install inetutils To be clear, brew install inetutils will ins ...
- dijkstra最短路
感觉自己太懒了,以后每天更博客激励自己吧. //时间复杂度O(n*n)的最短路算法 //首先需要设置一个访问数组v[maxn],一个数组d[maxn], memset(v,,sizeof(v)); ; ...
- Restful framework【第一篇】RESTful 规范
什么是RESTful REST与技术无关,代表的是一种软件架构风格,REST是Representational State Transfer的简称,中文翻译为“表征状态转移” REST从资源的角度类审 ...
- ubuntu安装微软雅黑和Consolas字体
原文:http://fooler5.iteye.com/blog/2406227 [字体下载] YaHeiConsolas.tar:http://www.mycode.net.cn/wp-conten ...
- P3244 [HNOI2015]落忆枫音
思路 给出了一个DAG,要求以1为根的外向树的个数 如果没有加边的条件,就非常好做 每个点都只保留一条入边,最后得到的一定就是一个符合条件的树了(因为给了一个DAG啊) 所以答案是\(\prod_{i ...
- (转载)MySQL基础(非常全)
MySQL基础 一.MySQL概述 1.什么是数据库 ? 答:数据的仓库,如:在ATM的示例中我们创建了一个 db 目录,称其为数据库 2.什么是 MySQL.Oracle.SQLite.Access ...
- 微服务架构与实践3_api
场景分析 描述产品服务,基于REST的接口 表述性状态转移(Representational State Transfer,REST) 任务拆分 将整体要做的工作内容划分成小的任务: 统一时间聚焦一个 ...
- Leetcode121-Best Time to Buy and Sell Stock I - Easy
I Say you have an array for which the ith element is the price of a given stock on day i. If you wer ...
- java根据URL获取网页编码
由于很多原因,我们要获取网页的编码(多半是写批量抓取的脚本吧...嘻嘻嘻) 注意: 如果你的目的是获取不乱码的网页内容(而不是根据网址发送post请求获取返回值),切记切记,移步这里 java根据UR ...
- Shell中的IFS
一.IFS 介绍 Shell 脚本中有个变量叫 IFS(Internal Field Seprator) ,内部域分隔符.完整定义是The shell uses the value stored in ...