MongoDB mongoose 的 save、insert 和 create 方法的比较

目录

[save 方法](#save 方法)

[insert 方法](#insert 方法)

[create 方法](#create 方法)

使用会话和事务

总结


在本文中,我们将介绍 MongoDB 中使用 mongoose 操作数据库时的三种常见方法:save、insert 和 create。这些方法可以用于将数据存储到 MongoDB 数据库中,并且在一定程度上具有相似的功能。然而,它们之间还存在一些差异和适用场景上的区别。下面我们将逐一进行讲解。

阅读更多:MongoDB 教程

save 方法

save 方法是 mongoose 中最常见的保存数据的方法,它可以保存一个已经存在的文档,也可以创建一个新的文档。当执行 save 方法时,mongoose 会先判断数据是否已经存在于数据库中,如果存在则更新数据,如果不存在则创建新的数据。

下面是一个使用 save 方法操作数据库的示例:

const mongoose = require('mongoose');
const Schema = mongoose.Schema;

// 定义数据模式
const userSchema = new Schema({
  name: String,
  age: Number,
  email: String
});

// 定义数据模型
const User = mongoose.model('User', userSchema);

// 创建一个文档实例
const user = new User({
  name: 'Tom',
  age: 28,
  email: 'tom@example.com'
});

// 保存数据到数据库
user.save()
  .then(() => {
    console.log('数据保存成功');
  })
  .catch(err => {
    console.log('数据保存失败:', err);
  });

insert 方法

insert 方法是一个底层的方法,它可以用来一次保存多个文档到数据库中。与 save 方法不同的是,insert 方法不会触发 mongoose 定义的中间件和钩子函数,速度更快。

下面是一个使用 insert 方法操作数据库的示例:

const mongoose = require('mongoose');
const Schema = mongoose.Schema;

// 定义数据模式
const userSchema = new Schema({
  name: String,
  age: Number,
  email: String
});

// 定义数据模型
const User = mongoose.model('User', userSchema);

// 创建多个文档实例
const users = [
  { name: 'Tom', age: 28, email: 'tom@example.com' },
  { name: 'Jerry', age: 25, email: 'jerry@example.com' },
  { name: 'Alice', age: 30, email: 'alice@example.com' }
];

// 保存多个文档到数据库
User.insertMany(users)
  .then(() => {
    console.log('数据保存成功');
  })
  .catch(err => {
    console.log('数据保存失败:', err);
  });

create 方法

create 方法是一个可以同时创建并保存文档到数据库的方法。它与save 方法不同的是,create 方法可以直接传入一个对象,而不需要先创建文档实例。create 方法也会触发 mongoose 定义的中间件和钩子函数。

下面是一个使用 create 方法操作数据库的示例:

使用会话和事务

除了传递对象数组之外,create() 还支持传入单个对象或对象的扩展。例如,下面是创建多个文档的另一种方法。

// 保存两个新文档。
await User.create({ name: 'O.O' }, { name: 'D.O' })

不幸的是,如果您想将选项传递给 create() 方法,比如您想使用 transactions,扩展语法会导致语法歧义。例如,下面的代码将尝试创建两个文档,而不是将第二个参数视为 options 对象。

const session = await User.startSession()
​
await session.withTransaction(async () => {
  // 注意,以下内容将不工作!它不是创建一个带有关联 session 的文档,而是创建两个没有 session 的文档!
  await User.create({ name: 'D.O' }, { session })
})

因此,如果要在事务中使用 create(),则必须将文档作为数组传递,即使只创建一个文档也是如此。

const session = await User.startSession()
​
await session.withTransaction(async () => {
  // 使用给定 session 创建一个文档。
  await User.create([{ name: 'D.O' }], { session })
})

总结

以上,我们介绍了 MongoDB 中 mongoose 的 save、insert 和 create 方法的使用。在选择方法时,可以根据实际需求和场景进行选择。

  • save 方法可用于保存已经存在的文档或新创建的文档,触发中间件和钩子函数。
  • insert 方法适用于批量插入文档,速度较快,不触发中间件和钩子函数。
  • create 方法适用于直接创建并保存文档,触发中间件和钩子函数。

根据具体情况选择合适的方法,可以更加高效地操作和管理 MongoDB 数据库中的数据。

相关推荐
努力的小雨1 分钟前
快速上手 KSQL:轻松与数据库交互的利器
数据库·经验分享
Gentle5864 分钟前
labview中连接sql server数据库查询语句
数据库·labview
Gentle5865 分钟前
labview用sql server数据库存取数据到一个单元格
数据库·labview
2401_857636398 分钟前
共享汽车管理新纪元:SpringBoot框架应用
数据库·spring boot·汽车
菲兹园长8 分钟前
表的设计(MYSQL)
数据库·mysql
Java Fans23 分钟前
MySQL数据库常用命令大全(完整版——表格形式)
数据库·mysql
起飞的风筝35 分钟前
【redis】—— 环境搭建教程
数据库·redis·缓存
白萝卜弟弟39 分钟前
【MySQL】MySQL函数之JSON_EXTRACT
数据库·mysql·json
gjh120841 分钟前
MySQL常见面试题
数据库·mysql
Rverdoser2 小时前
Python & PyQt5 实现 .his 文件批量转 Excel 工具
数据库