node教程(四)Mongodb+mongoose

文章目录

一、mongodb

1.简介

1.1Mongodb是什么?

Mongodb是一个基于分布式文件存储的数据库

1.2数据库是什么?

数据库是按照数据结构来组织、存储和管理数据的应用程序。

1.3数据库的作用

主要作用就是管理数据,对数据进行增删改查

1.4数据库管理数据的特点

相比于纯文件,数据库管理数据具有如下特点:

1.速度更快

2.拓展性更强

3.安全性更强

2.核心概念

2.核心概念

Mongodb中有三个重要概念

  • 数据库是一个数据仓库,数据库服务下可以创建很多数据库,数据库中可以存放很多集合
  • 集合:集合类似于JS中的数组,在集合中可以存放很多文档
  • 文档:文档是数据库中的最小单位,类似于JS中的对象

3.下载安装与启动

https://www.mongodb.com/try/download/community

千万不要选中服务端窗口的内容,选中会停止服务,可以敲回车取消选中

4.命令行交互

4.1数据库命令

1.显示所有的数据库

powershell 复制代码
show dbs

2.切换到指定的数据库,如果数据库不存在则会自动创建数据库

powershell 复制代码
use 数据库名

3.显示当前所在数据库

powershell 复制代码
db

4.删除当前数据库

powershell 复制代码
use 库名
db.dropDatabase()

4.2集合命令

1.创建集合

powershell 复制代码
db.createCollection('集合名称')

2.显示当前数据库中的所有集合

powershell 复制代码
show collections

3.删除某个集合

powershell 复制代码
db.集合名.drop()

4.重命名集合

powershell 复制代码
db.集合名.renameCollection('new name')

4.3文档命令

1.插入文档

powershell 复制代码
db.集合名.insert('文档对象')

2.查询文档

powershell 复制代码
db.集合名.find(查询条件)

_id是mongodb自动生成的唯一编号,用来唯一标识文档

3.更新文档

powershell 复制代码
db.集合名.update(查询条件,新的文档)
db.集合名.update({name:'张三'},{$set:{age:19}})

4.删除文档

powershell 复制代码
db.集合名.remove(查询条件)

二、Mongoose

1.介绍

是一个对象文档模型库

2.作用

方便使用代码操作mongodb数据库

3.使用流程

javascript 复制代码
// 安装mongoose
// 导入mongoose
const mongoose = require('mongoose');

// 连接mongodb服务                      数据库的名称
mongoose.connect('mongodb://127.0.0.1:27017/abc')

/* 设置回调 */
mongoose.connection.on('open',() => {
    console.log('连接成功');
}); // 设置连接成功的回调
mongoose.connection.on('error',() => {
    console.log('连接失败');
}); //连接失败的回调
mongoose.connection.on('close',() => {
    console.log('连接关闭');
}); //设置连接关闭的回调

// 关闭mongodb的连接
setTimeout(() => {
    mongoose.disconnect();
},2000)

4.插入文档

出现以下问题

powershell 复制代码
 throw new MongooseError('Model.create() no longer accepts a callback');

是由于mongoose版本太高,可以手动降级

powershell 复制代码
npm i mongoose@6.8.0
javascript 复制代码
// 安装mongoose
// 导入mongoose
const mongoose = require('mongoose');

// 连接mongodb服务                      数据库的名称
mongoose.connect('mongodb://127.0.0.1:27017/abc')

/* 设置回调 */
mongoose.connection.once('open',() => {
    // console.log('连接成功');
    // 5.创建文档的结构对象
    // 设置集合中文档的属性以及属性值的类型
    let BookSchema = new mongoose.Schema({
        name:String,
        author: String,
        price: Number
    });

    // 创建模型对象  对文档操作的封装对象
    let BookModel = mongoose.model('books',BookSchema);

    // 新增
    BookModel.create({
        name:'xiyouji',
        author:'吴承恩',
        price:19.9
    },(err,data) => {
        if(err){
            console.log(err);
            return;
        }
        // 如果没有出错,则输出插入后的文档对象
        console.log(data);
        // 关闭数据库连接(项目运行过程中不会添加此代码)
        mongoose.disconnect();
    });

}); // 设置连接成功的回调

mongoose.connection.on('error',() => {
    console.log('连接失败');
}); //连接失败的回调
mongoose.connection.on('close',() => {
    console.log('连接关闭');
}); //设置连接关闭的回调

5.mongoose字段类型

文档结构可选的常用字段类型列表

javascript 复制代码
// 安装mongoose
// 导入mongoose
const { Mixed } = require('mongoose');
const mongoose = require('mongoose');

// 连接mongodb服务                      数据库的名称
mongoose.connect('mongodb://127.0.0.1:27017/abc')

/* 设置回调 */
mongoose.connection.once('open',() => {
    // console.log('连接成功');
    // 5.创建文档的结构对象
    // 设置集合中文档的属性以及属性值的类型
    let BookSchema = new mongoose.Schema({
        name:String,
        author: String,
        price: Number,
        is_hot:Boolean,
        tags:Array,
        pub_time:Date,
        test:mongoose.Schema.Types.Mixed 
    });

    // 创建模型对象  对文档操作的封装对象
    let BookModel = mongoose.model('books',BookSchema);

    // 新增
    BookModel.create({
        name:'xiyouji',
        author:'吴承恩',
        price:19.9,
        is_hot:true,
        tags:['鬼怪','励志'],
        pub_time:new Date(),
        test:'abc'
    },(err,data) => {
        if(err){
            console.log(err);
            return;
        }
        // 如果没有出错,则输出插入后的文档对象
        console.log(data);
        // 关闭数据库连接(项目运行过程中不会添加此代码)
        mongoose.disconnect();
    });

}); // 设置连接成功的回调

mongoose.connection.on('error',() => {
    console.log('连接失败');
}); //连接失败的回调
mongoose.connection.on('close',() => {
    console.log('连接关闭');
}); //设置连接关闭的回调
相关推荐
豆芽脚脚3 小时前
MongoDB 导出和导入完整指南
数据库·mongodb
烧饼Fighting3 小时前
Mysql替换为瀚高数据库部分函数转换V4.5版本
数据库·mysql
上善若水_厚德载物4 小时前
Centos7 Mysql 5.7 读写分离
数据库·mysql
Mr__Miss4 小时前
Redis的持久化
数据库·redis·缓存
CCPC不拿奖不改名4 小时前
SQL基础(SQL小白教程):MySQL语句+环境一键搭建+面试习题
数据库·sql·计算机网络·mysql·oracle·面试·职场和发展
陈文锦丫4 小时前
JAVA面试
数据库·mysql
sunfove5 小时前
将 Python 仿真工具部署并嵌入个人博客
开发语言·数据库·python
冰清-小魔鱼6 小时前
各类数据存储结构总结
开发语言·数据结构·数据库
深藏bIue7 小时前
MongoDB 4.4.30安装、数据迁移
数据库·mongodb
benyuanone7 小时前
MySQL环境项目迁移成国产化达梦环境
数据库·mysql