MongoDB 的简介
MongoDB是一个基于分布式文件存储的数据库。由C++语言编写,旨在为WEB应用提供可扩展的高性能数据存储解决方案。
MongoDB 术语/概念
SQL术语/概念 | MongoDB术语/概念 | 解释说明 |
---|---|---|
database | database | 数据库 |
table | collection | 数据库表/集合 |
row | document | 数据记录行/文档 |
column | field | 数据字段/域 |
index | index | 索引 |
table joins | --- | 表连接,MongoDB不支持 |
primary key | primary key | 主键,MongoDB自动将_id字段设置为主键 |
MongoDB - 数据库
- 一个mongodb中可以建立多个数据库。
- MongoDB的单个实例可以容纳多个独立的数据库,每一个都有自己的集合和权限,不同的数据库也放置在不同的文件中。
MongoDB - 文档
- 文档是一组键值对
- MongoDB 的文档不需要设置相同的字段,并且相同的字段不需要相同的数据类型,这与关系型数据库有很大区别,也是 MongoDB 非常突出的特点。
//一个简单的文档例子
{"genres": ["犯罪", "剧情"], "title": "肖申克的救赎"}
MongoDB - 集合
- 集合就是MongoDB的文档集合。类型于关系型数据库中的表格。
- 集合存在于数据库中,集合没有固定的结构,这意味着你在对集合可以插入不同格式和类型的数据,但通常情况下我们插入集合的数据都会有一定的关联性。
//一个简单的集合例子
{"genres": ["犯罪", "剧情"], "title": "肖申克的救赎"} //文档
{"genres": ["搞笑", "无聊"], "title": "李茶的姑妈"}
{"genres": ["好看"], "title": "无双", "stars": 9}
MongoDB 语句来操作数据库
show dbs //显示数据库 (无内容数据库不显示)
db/db.getName() //查看当前所处数据库
use XXX //创建/切换数据库
db.stats() //显示当前db状态
db.dropDatabase() //删除当前数据库
增
- insertOne
- insertMany
- db.XXX.insertOne({}) //XXX表名
- db.XXX.insertMany({name:'zhangshan',age:19},{name:'lisi',age:20}) //增加多条
删
- deleteOne
- deleteMany
改
- updateOne
- updateMany
- db.XXX.updateOne(查询条件,修改内容)
- db.XXX.updateMany(查询条件,修改内容)
db.hello.updateOne({name:'zhangshan'},{$set : {age:20}}) //修改一条
db.hello.updateMany({name:'zhangshan'},{$set : {age:20}}) //修改多条
查
db.XXX.find() //查询所有记录 sql:select * from users
db.XXX.find(查询条件)
db.XXX.find({'age': 22}); //查询 age = 22 的记录 select * from users where age = 22;
db.XXX.find({age:{$gt:20}}) //查询年龄大于20的
db.XXX.find({age:{$lt:20}}) //查询年龄小于20的
db.XXX.find({age:{$gte:20}}) //查询年龄大于等于20的
db.XXX.find({age:{$1te:20}}) //查询年龄小于等于20的
db.XXX.find({'age': {$ne: 22}}); //查询 age != 22 的记录
db.XXX.find({'age': {$gte: 23, $lte: 26}}); //查询 age >= 23 并且 age <= 26
db.XXX.find({$or: [{age: {$gte: 23}}, {name: '张三'}]); //查询 age >= 23 或者 name == '张三'
db.XXX.find({'name': /mongo/}); //查询 name 中包含 mongo 的数据 select * from users where name like %mongo%;
db.XXX.find({'name': /^mongo/}); //查询 name 中已 mongo 开头的数据
db.XXX.find({'name': /mongo$/}); //查询 name 中已 mongo 结尾的数据
db.XXX.find({}, {name: 1, age: 1}); //查询 指定列 name 、age 的数据
db.XXX.find({age: {$gt: 25}}, {name: 1, age: 1}); //查询 指定列 name 、age 并且 age > 25
db.XXX.find().sort({age: 1}); //升序 倒序传-1
db.XXX.find({name:'zhangshan'},{age:20}) //查询 name = zhangsan , age = 20 的数据
db.XXX.find().limit(5); //查询 前5条数据
db.XXX.find().skip(10); //查询 10条以后的数据
db.XXX.find().limit(10).skip(5); //查询 在 5 - 10 之间的数据
db.XXX.find().count(); //查询 某个结果集的记录条数
db.XXX.findOne(); //查询第一条数据
使用 skip() 与 limit() 实现分页
- pageNum 当前第几页
- pageSize 每页显示多少条
- totalPage 一共有几页 Math.ceil (totalSize/pageSize)
- totalSize 一共有多少条数据 db.XXX.find().count()
第一页: db.XXX.find().skip((pageNum - 1) * pageSize).limit(pageSize)
第二页: db.XXX.find().skip(10).limit(10)
第三页: db.XXX.find().skip(20).limit(10)
第四页: db.XXX.find().skip(30).limit(10)
Mongoose
是一款能够在 nodejs 中操作 MongoDB 数据库的模块
两个核心概念点
- schema
表示数据库表结构的一种格式
{
key : value
key -> 表中字段的名字
value -> string | object
name : string
age :number
password: {
type :string, //传递的数据类型
required :true, //表示这个字段必须要传递
default : '123' //默认值
}
}
- model
基于某个 schema 生成的某个表的模型对象,生成的模型对象上就有一系列的对数据库这张表操作的方法
使用步骤
创建文件 npm init -y(初始化) -> npm install --save express(安装依赖)
- 安装 mongoose npm install --save mongoose
- 建立 MongoDB 链接对象
- 创建某张表的 schema 与相对应的 model
- 基于第3步中的 model 来对这张表进行操作(server.js)
- 2.建立 MongoDB 链接对象 :在项目目录下创建文件夹(进行配置 config) ->创建js文件(作用:暴露数据链接了MongoDB的mongoose对象)
//1.引入 mongoose
const mongoose = require("mongoose");
//2.定义数据库的链接地址 37代表数据库的名字
const url = 'mongodb://127.0.0.1:27017/37'; //这里是mongodb协议 MongoDB的端口号为27017
//3.mongoose.connect 方法来链接 返回的是promise对象
mongoose
.connect(url, { useNewUrlParser: true }) //connect参数2是个对象 为可选参数 当出现useNewUrlParser警告时 再来设置
.then(() => {
console.log("数据库链接成功");
})
.catch(err => {
console.log("数据库链接失败", err.message);
});
// 4. 暴露已经链接了数据库的 mongoose 对象
module.exports = mongoose;
- 3.创建某张表的 schema 与相对应的 model : 在项目目录下创建文件夹 (用于生成模型对象的 models) -> 创建js文件(作用:生成XXX表的模型对象)
1. 引入链接了数据库的 mongoose 对象 (链接前面暴露出来的js文件)
const db = require('../XXjs');
2. 定义这张表(集合)的 schema 对象
const schema = new db.Schema({ //db中有一个Schema的构造函数 设置需要的字段格式
// key: value 的设置
name: {
type: String, //类型首字母大写
required: true //定义必须存在
},
age: {
type: Number,
default: 18 //默认为18
},
sex: {
type: Number,
default: 1
}
});
3. 基于第2步中的 schema 生成 model 对象并暴露model db.model()方法
module.exports = db.model('student',schema); //数据库的表名是根据 db.model 第一个参数的复数形式来确定的
- 基于第3步中的 model 来对这张表进行操作(server.js)
//点出重点和一些使用方法
//引入3中生成的model对象
const StudentModel = require('./models/student');
//req.query 获取get请求传递过来的参数
//req.body 获取post请求传递过来的参数
//增
//生成模型的实例对象如student
//将实例对象(其中的数据从前端获得)写入数据库
student.save() //save() 往数据库插入数据时,会更新重复的数据
//查(这里是获取所有数据给前端)
StudentModel.find() 可获取所有的数据
//改
StudentModel.updateOne() //(只修改一个){要修改的条件(数据库中修改参数的名字),要修改的内容}
//删
StudentModel.deleteOne() //只删除一个
//分页
//pageNum 当前第几页
//pageSize 每页显示多少条
//totalPage 一共有几页 Math.ceil (totalSize/pageSize)
//totalSize 一共有多少条数据 db.XXX.find().count(
Robo 3T 1.3 :图像化界面