TypeScript 中如何使用 TypeORM 来简化数据库操作

阅读时长 6 分钟读完

在前端开发中,经常需要对数据库进行操作,这是一个比较繁琐的工作。而使用 ORM(Object-Relational Mapping)框架可以简化这个过程。TypeORM 是一个基于 TypeScript 的 ORM 框架,它支持多种数据库,并提供了一整套操作数据库的 API。在本文中,我们将介绍如何使用 TypeORM 来简化数据库操作。

安装 TypeORM

在开始使用 TypeORM 之前,需要先安装它。可以使用以下命令来安装:

需要注意的是,TypeORM 还需要使用到 reflect-metadata,所以也需要安装。

配置数据库连接

在使用 TypeORM 之前,需要先配置数据库连接。这可以通过在项目中创建一个 ormconfig.json 文件来实现。以下是一个示例配置:

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

这个配置文件中包含了数据库连接的相关信息,例如数据库类型、主机名、端口号、用户名、密码、数据库名等。还定义了实体、迁移和订阅器的路径,这些都是 TypeORM 中的概念,稍后我们会详细介绍。

定义实体

在 TypeORM 中,实体是指与数据库表相对应的 TypeScript 类。以下是一个示例 User 实体的定义:

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

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

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

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

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

在这个示例中,我们使用了 Entity、Column 和 PrimaryGeneratedColumn 装饰器来定义实体的属性。Entity 装饰器表示这是一个实体类,Column 装饰器表示这是一个列,PrimaryGeneratedColumn 装饰器表示这是一个自动生成的主键列。

创建和查询实体

在使用 TypeORM 操作数据库时,最常用的两个操作是创建和查询实体。

创建实体

要创建一个实体,可以使用 create 和 save 方法。以下是一个示例:

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

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

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

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

在这个示例中,我们首先获取了 UserRepository 对象,然后使用 create 方法创建了一个 User 实例。最后使用 save 方法将实例保存到数据库中。

查询实体

要查询实体,可以使用 find、findOne 和 findAndCount 方法。以下是一个示例:

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

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

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

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

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

在这个示例中,我们首先获取了 UserRepository 对象,然后使用 find 方法查询了所有的 User 实例。接着使用 findOne 方法查询了满足条件的 User 实例。最后使用 findAndCount 方法查询了所有的 User 实例和它们的数量。

更新和删除实体

在 TypeORM 中,更新和删除实体也非常简单。以下是一个示例:

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

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

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

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

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

在这个示例中,我们首先使用 findOne 方法查询了要更新的 User 实例,然后修改了它的密码,并使用 save 方法将其更新到数据库中。接着使用 delete 方法删除了该实例。

总结

在本文中,我们介绍了如何使用 TypeORM 来简化数据库操作。首先安装了 TypeORM 和 reflect-metadata,然后配置了数据库连接。接着定义了实体,并介绍了创建、查询、更新和删除实体的方法。TypeORM 提供了大量的 API,可以让我们更加方便地操作数据库,从而提高开发效率。

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

纠错
反馈