Sequelize ORM 使用说明:如何使用 findOrCreate 进行查找并新增操作?

阅读时长 4 分钟读完

Sequelize 是一种流行的 ORM(对象关系映射)框架,可用于 Node.js 应用程序。它允许您使用 JavaScript 查询和操作关系数据库,而不必编写 SQL 语句。其中一种常见的用例是在数据库中查找或创建记录。这在许多应用程序中都很有用,例如用户数据和配置文件等。

本文将介绍 Sequelize 中的 findOrCreate 方法,它允许您按条件查找数据库记录,并在查找不到时创建新记录。我们将探索该方法的具体用法,以及什么情况下最适合使用它。

安装与配置

首先,确保已经安装了 Sequelize 和您要连接的数据库驱动程序。例如,如果您想连接 MySQL 数据库,则需要安装 mysql2 驱动程序:

在此之后,只需通过以下方式初始化 Sequelize:

这里你还可以设置许多选项来配置数据库连接,包括端口号、SSL 等验证选项。有关详细信息,请参阅 Sequelize 文档。

findOrCreate 方法

现在,假设我们有一个名为 User 的模型和一个包含用户记录的名为 users 的表。我们希望按条件查找具有给定属性的用户记录,如果没有符合条件的记录,则创建一条新记录。在这种情况下,我们可以使用 findOrCreate 方法。

以下是 findOrCreate 的基本语法:

  • Model:要执行操作的模型。
  • where:一个对象,指定执行查询时要匹配的条件。例如,{ name: 'John Doe' } 可以用来查找所有名为 'John Doe' 的用户记录。
  • defaults:一个对象,指定要创建新记录的默认值(如果不存在与 where 匹配的记录)。例如,{ name: 'Jane Doe', email: 'jane.doe@example.com' } 可以用来创建一个新的名为 'Jane Doe',电子邮件地址为 'jane.doe@example.com' 的用户记录。

请注意,如果找到符合条件的记录,将返回该记录和一个标志,表示是否已经存在此记录。如果没有找到符合条件的记录,将创建并返回新记录。这意味着 findOrCreate() 操作总是返回一个包含两个元素的数组,第一个元素是要么是符合条件的数据库记录,要么是新创建的记录,第二个元素是布尔值表示记录是否是新创建的。

现在,让我们看看一个更具体的示例:检索 name 属性等于 'Alice' 的用户记录。如果找到记录,则返回该记录;否则,创建一条新记录并将其属性设置为 { name: 'Alice', email: 'alice@example.com' }

-- -------------------- ---- -------
----- ------ -------- - ----- -------------------
  ------ - ----- ------- --
  --------- - ------ ------------------- -
---

-- --------- -
  -------------------- --- ------- -----------
- ---- -
  ------------------ -------- ------- -----------
-

这里我们使用了 await 关键字,因为 findOrCreate 方法返回一个 Promise,需要等待执行完成后才能获取到结果。根据创建的情况,created 变量将设置为布尔值。如果是 true,则意味着没有找到符合条件的记录并已经创建了新的记录,如果是 false,则意味着已经找到了符合条件的记录。

总结

本文介绍了 Sequelize ORM 中的 findOrCreate 方法

来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/652962c37d4982a6ebbed63e

纠错
反馈