Express.js 中使用 Sequelize-CLI 进行数据库管理

阅读时长 8 分钟读完

前言

在网站或应用开发中,数据库是扮演着重要角色的一个组件。在今天,我们有许多数据库选项,例如:MongoDB、MySQL、PostgreSQL等等。而在开发过程中,我们通常也需要管理我们的数据库。这篇文章将会向大家介绍如何在 Express.js 中使用 Sequelize-CLI 进行数据库管理。

什么是 Sequelize-CLI

Sequelize-CLI 是 Sequelize 的命令行工具,我们可以使用它来初始化、迁移和填充我们的数据库。Sequelize-CLI 还提供了几个基本的命令来执行这些任务。它还支持 Node.js 的生命周期,使我们的数据库管理更加容易。

使用 Sequelize-CLI

安装

首先,我们需要全局安装 Sequelize-CLI

初始化

接下来,我们将初始化一个新的 Sequelize 项目。我们可以使用以下命令快速创建一个新的 Sequelize 项目

此命令初始化一个新的 Sequelize 项目,包括一个新的文件夹 /config 用于数据库配置和 /migrations 用于迁移。

配置

接下来,我们需要在 config 文件夹下创建 config.json 文件,以定义如何与数据库交互。

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

以上配置是通过 json 格式来管理的,分别定义了 development、test 和 production 三种不同环境下的数据库信息。

创建模型

接下来,我们要使用 Sequelize-CLI 来创建模型文件。模型是映射到数据库表的 JavaScript 对象。我们可以使用以下命令来创建模型:

以上命令是以 "User" 为名称并创建一个新的模型。模型包含三个属性:firstName、lastName 和 email,它们都是字符串数据类型。

模型文件将会在项目的 /models 目录下生成。同时,会在 migrations 目录下生成一个新的文件,与模型关联起来,管理表的迁移。

数据库迁移

接下来,我们要在数据库中创建新表。我们可以使用以下命令来执行数据库迁移:

以上命令将会执行 /migrations 目录下的所有迁移文件。如果我们对某些已经迁移的操作进行了修改,我们应该使用以下命令进行回滚:

以上命令将会撤销最新的迁移。

初始化数据

最后,我们需要向数据库中填充数据。我们可以使用 Sequelize-CLI 提供的 seed 命令来填充数据。

首先我们需要通过下面的命令来生成一个 seeds 文件

以上命令将会在当前目录下创建一个 seeds 目录,并在该目录下创建一个名为 "demo-user" 的文件。

接下来,我们可以在 "demo-user.js" 中添加以下代码,向数据库中添加用户信息:

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

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

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

以上代码中,我们使用了 queryInterface 提供的 bulkInsert 和 bulkDelete 函数,向数据库中添加和删除记录。

最后,我们可以使用以下命令执行此 Seed 文件:

以上命令将会执行 Seeds 文件的 up 函数,向数据库中添加记录。

总结

Sequelize-CLI 是一个非常方便的用于管理 Sequelize 项目的工具。使用 Sequelize-CLI 我们可以轻松的进行数据库的迁移,填充以及回滚。这样可以更好的保持我们的数据库的结构的一致性。尤其是在大型项目中,管理数据库将变得更加便利,开发效率也更加高效。

示例代码

以上是我们如何在 Sequelize 中使用 Sequelize-CLI 进行数据库管理的详细指导,下面是对应的示例代码

models/User.js

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

migrations/20210623143423-create-user.js

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

seeds/demo-user.js

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

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

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

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

纠错
反馈