使用 Express.js + Sequelize 实现 ORM

阅读时长 5 分钟读完

ORM(Object-Relational Mapping) 是一种将对象模型和关系型数据库模型进行映射的技术。在前端开发中,ORM 技术可以帮助我们更好地管理数据库,并且在代码编写时能够更加简洁明了。本篇文章将介绍如何使用 Express.js 和 Sequelize 实现 ORM。

什么是 Express.js 和 Sequelize?

Express.js 是一个基于 Node.js 平台的 Web 开发框架,它提供了一系列的工具和中间件,可以帮助我们快速地构建 Web 应用程序。Sequelize 是一个支持多种数据库的 ORM 框架,它可以帮助我们更加方便地管理数据库。

安装和配置

在开始使用 Express.js 和 Sequelize 实现 ORM 之前,我们需要先安装并配置相应的环境。首先,我们需要安装 Node.js 和 npm。然后,使用 npm 安装 Express.js 和 Sequelize:

接着,我们需要在项目中引入这两个库,并进行相关的配置:

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

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

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

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

在上面的代码中,我们首先引入了 Express.js 和 Sequelize,然后创建了一个 Express.js 应用程序实例,并创建了一个 Sequelize 实例。在创建 Sequelize 实例时,我们需要传入数据库的相关信息,比如数据库名、用户名、密码等等。这里我们使用了 MySQL 数据库,因此选择了 MySQL 方言。

定义模型

在使用 Sequelize 进行 ORM 开发时,我们需要定义模型(Model)。模型是指与数据库中某张表对应的 JavaScript 对象,它定义了表中的字段、数据类型以及一些其他属性。我们可以使用 Sequelize 提供的 define 方法来定义模型。

例如,我们定义一个名为 User 的模型,它对应着数据库中的 users 表:

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

在上面的代码中,我们定义了一个名为 User 的模型,并指定了它对应的表名为 users。模型中包含了三个字段,分别为 id、name 和 age。其中,id 字段为主键,自增;name 和 age 字段都不能为空。

增删改查

有了模型之后,我们就可以使用 Sequelize 进行增删改查操作了。下面是一些常见的操作示例:

创建新记录

在上面的代码中,我们使用了 create 方法来创建一条新的记录,并将其保存到数据库中。create 方法返回一个 Promise 对象,当创建成功时,会返回创建的记录对象。

查询记录

在上面的代码中,我们使用了 findAll 方法来查询所有的记录,并将查询结果打印到控制台上。

更新记录

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

在上面的代码中,我们使用了 update 方法来更新记录。update 方法接受两个参数,第一个参数是要更新的数据,第二个参数是一个对象,用于指定更新的条件。在本例中,我们将名为 Tom 的记录的年龄更新为 21。

删除记录

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

在上面的代码中,我们使用了 destroy 方法来删除记录。destroy 方法接受一个对象参数,用于指定删除的条件。在本例中,我们删除了名为 Tom 的记录。

总结

本文介绍了如何使用 Express.js 和 Sequelize 实现 ORM,包括安装和配置、定义模型以及常见的增删改查操作。ORM 技术可以帮助我们更好地管理数据库,并且在代码编写时能够更加简洁明了。在实际项目中,我们可以根据具体需求来使用不同的 ORM 框架。

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

纠错
反馈