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)查看所有数据

相关推荐
睡觉的时候不会困5 小时前
Redis 主从复制详解:原理、配置与主从切换实战
数据库·redis·bootstrap
程序员的世界你不懂7 小时前
【Flask】测试平台开发,新增说明书编写和展示功能 第二十三篇
java·前端·数据库
自学也学好编程7 小时前
【数据库】Redis详解:内存数据库与缓存之王
数据库·redis
JAVA不会写7 小时前
在Mybatis plus中如何使用自定义Sql
数据库·sql
IT 小阿姨(数据库)7 小时前
PgSQL监控死元组和自动清理状态的SQL语句执行报错ERROR: division by zero原因分析和解决方法
linux·运维·数据库·sql·postgresql·centos
ChinaRainbowSea8 小时前
7. LangChain4j + 记忆缓存详细说明
java·数据库·redis·后端·缓存·langchain·ai编程
小马学嵌入式~9 小时前
嵌入式 SQLite 数据库开发笔记
linux·c语言·数据库·笔记·sql·学习·sqlite
Java小白程序员9 小时前
MyBatis基础到高级实践:全方位指南(中)
数据库·mybatis
Monly219 小时前
人大金仓:merge sql error, dbType null, druid-1.2.20
数据库·sql
不宕机的小马达10 小时前
【Mysql|第一篇】Mysql的安装与卸载、Navicat工具的使用
数据库·mysql