node插件MongoDB(四)—— 库mongoose 操作文档使用(新增、删除、更新、查看文档)(二)

文章目录


前言

(1)问题:安装的mongoose 库版本不应该过高导致的问题

比如我默认安装8.0的版本就会报下面的错误

throw new MongooseError('Model.create() no longer accepts a callback'); MongooseError: Model.create() no longer accepts a callback

(2)重新安装低版本

base 复制代码
npm i mongoose@6.8.0

package.json 如下图


一、插入文档

1. 代码

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


mongoose.set('strictQuery', true); // 解决终端警告的问题
// 2: 连接 mongodb 服务
// mongodb: 表示mongodb 服务,而不是http服务
// 27017 表示端口号
// test 表示数据库名
mongoose.connect('mongodb://127.0.0.1:27017/test')

// 3:设置回调
// 3.1 设置连接成功的回调
// 设置连接成功的回调: once 事件回调函数只执行一次
mongoose.connection.once('open', () => {
    console.log('连接成功');
    // 4:创建文档的结构对象
    // 设置集合中文档的属性以及属性值的类型
    let userSchema = new mongoose.Schema({
        name: String,
        age: Number,
        sex: String
    })
    // 5:创建模型对象   对文档操作的封装对象
    let userModel = mongoose.model("user", userSchema)

    // 6: 新增
    userModel.create({
        name: '张三',
        age: 18,
        sex: '男'
    }, function (err, data){
        // err 判断是否有错误
        if (err) {
            console.log(err)
            return;
        } 
        console.log(data);
        // 7:关闭数据库链接(实际项目中不会添加该代码)
        mongoose.disconnect();
    })
})
// 3.2 设置连接错误的回调
mongoose.connection.on('error', () => {
    console.log('连接错误');
})
// 3.3 设置连接关闭的回调
mongoose.connection.on('close', () => {
    console.log('连接关闭');
})

2. node终端效果

3. 使用mongo.exe查询数据库的内容

4:注意点

为什么创建的集合名和在mongo.exe中查询的名字不一样呢?

二、删除文档

1. 删除一条

deleteOne 删除一条数据的方法

2. 批量删除

delectMany 批量删除数据的方法

3. 代码

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


mongoose.set('strictQuery', true); // 解决终端警告的问题
// 2: 连接 mongodb 服务
// mongodb: 表示mongodb 服务,而不是http服务
// 27017 表示端口号
// test 表示数据库名
mongoose.connect('mongodb://127.0.0.1:27017/test')

// 3:设置回调
// 3.1 设置连接成功的回调
// 设置连接成功的回调: once 事件回调函数只执行一次
mongoose.connection.once('open', () => {
    console.log('连接成功');
    // 4:创建文档的结构对象
    // 设置集合中文档的属性以及属性值的类型
    let userSchema = new mongoose.Schema({
        name: String,
        age: Number,
        sex: String
    })
    // 5:创建模型对象   对文档操作的封装对象
    let userModel = mongoose.model("user", userSchema)

    // 6: 删除一条
    // userModel.deleteOne({ _id: '654cf280d53122b083bea83f' }, (err, data) => {
    //     // err 判断是否有错误
    //     if (err) {
    //         console.log('删除失败', err)
    //         return;
    //     } 
    //     console.log(data);
    // })
    
    // 7:批量删除
    // 删除性别为男的所有数据
    userModel.deleteMany({ sex: '男' }, (err, data) => {
        // err 判断是否有错误
        if (err) {
            console.log('删除失败', err)
            return;
        } 
        console.log(data);
    })
})
// 3.2 设置连接错误的回调
mongoose.connection.on('error', () => {
    console.log('连接错误');
})
// 3.3 设置连接关闭的回调
mongoose.connection.on('close', () => {
    console.log('连接关闭');
})

三、修改文档

和删除一样,不过多描述,记住方法即可

updateOne 修改一条

updateMany 批量修改

1. 修改一条

2. 批量修改

四、查看文档

注意查看所有和删除和更新不一样,查询所有的方法是find。后面是没有Many的

findOne 查看一条
find 查看所有 (不是findMany)第一个参数不加就返回所有数据,加上就返回符合条件的所有数据。

1. 查看一条(findOne)

2. 查看所有(find )

(1)查看所有符合条件的数据

(2)查看所有数据

相关推荐
清风6666662 小时前
基于单片机的水塔液位检测与智能调节报警系统设计
数据库·单片机·嵌入式硬件·毕业设计·课程设计·期末大作业
gplitems1232 小时前
Technox – IT Solutions & Services WordPress Theme: A Practical
linux·服务器·数据库
不剪发的Tony老师3 小时前
MySQL 9.5创新版发布,有哪些新功能?
数据库·mysql
布朗克1683 小时前
MySQL 及 SQL 注入详细说明
数据库·sql·mysql·1024程序员节
武子康4 小时前
Java-154 深入浅出 MongoDB 用Java访问 MongoDB 数据库 从环境搭建到CRUD完整示例
java·数据库·分布式·sql·mongodb·性能优化·nosql
Austindatabases4 小时前
DBA 从“修电脑的” 到 上演一套 “数据治理” 大戏 --- 维护DBA生存空间,体现个体价值
数据库·dba
LB21124 小时前
Redis黑马点评 day01
数据库·redis·缓存
白小筠5 小时前
创建Django项目
数据库·django·sqlite
扑克中的黑桃A6 小时前
金仓多模数据库平替MongoDB的电子证照国产化实践——从2TB数据迁移到1600+并发支撑
数据库
计算机毕业设计小帅6 小时前
【2026计算机毕业设计】基于Django的社区婴幼儿预防接种系统
数据库·django·课程设计