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 [email protected]
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('连接关闭');
}); //设置连接关闭的回调
相关推荐
我在北京coding7 分钟前
300道GaussDB(WMS)题目及答案。
数据库·gaussdb
小Tomkk19 分钟前
阿里云 RDS mysql 5.7 怎么 添加白名单 并链接数据库
数据库·mysql·阿里云
明月醉窗台1 小时前
qt使用笔记二:main.cpp详解
数据库·笔记·qt
沉到海底去吧Go2 小时前
【图片自动识别改名】识别图片中的文字并批量改名的工具,根据文字对图片批量改名,基于QT和腾讯OCR识别的实现方案
数据库·qt·ocr·图片识别自动改名·图片区域识别改名·pdf识别改名
老纪的技术唠嗑局2 小时前
重剑无锋,大巧不工 —— OceanBase 中的 Nest Loop Join 使用技巧分享
数据库·sql
未来之窗软件服务3 小时前
JAVASCRIPT 前端数据库-V6--仙盟数据库架构-—-—仙盟创梦IDE
数据库·数据库架构·仙盟创梦ide·东方仙盟·东方仙盟数据库
一只爱撸猫的程序猿4 小时前
构建一个简单的智能文档问答系统实例
数据库·spring boot·aigc
nanzhuhe4 小时前
sql中group by使用场景
数据库·sql·数据挖掘
消失在人海中4 小时前
oracle sql 语句 优化方法
数据库·sql·oracle
Clang's Blog4 小时前
一键搭建 WordPress + MySQL + phpMyAdmin 环境(支持 PHP 版本选择 & 自定义配置)
数据库·mysql·php·wordpr