【问题标题】:How to catch a Typeorm transaction error in NestJs如何在 NestJs 中捕获 Typeorm 事务错误
【发布时间】:2019-11-25 02:46:27
【问题描述】:

我有一个用 node.js 和 nestJs 编写的服务器端,用 typeorm 查询。

我正在尝试使用here 建议的事务将一些查询包装到数据库中,并在 typeorm 的docs 的启发下进行了一些更改,如下所示:

getManager().transaction(async transactionalEntityManager => {
    transactionalEntityManager.save<Entity>(newEntity)
    transactionalEntityManager.save<Entity1>(newEntity1)
});

事务运行良好,如果出现错误则回滚数据库。 以这种方式测试:

getManager().transaction(async transactionalEntityManager => {
    transactionalEntityManager.save<Entity>(newEntity)
    throw 'There is an error'
    transactionalEntityManager.save<Entity1>(newEntity1)
});

事务的执行在 graphQL Mutation 中,所以如果出现问题我应该向客户端返回一个错误,问题是我无法从事务中捕获错误。

试过这样做:

  @Mutation(returns => Entity)
  async create(): Promise<Entity> {
    let entity = null;
    let error = null;
    getManager().transaction(async transactionalEntityManager => {
      try {
        entity = await transactionalEntityManager.save<Entity>(newEntity)
        await transactionalEntityManager.save<Entity1>(newEntity1);
      } catch (err) {
        error = err
      }
    })
    if (error) {
      return error
    }
    return entity
  }

当我抛出错误时,我成功地捕获了它,但是当真正的错误发生时,我可以在服务器中 console.log() 它但它永远不会返回到客户端。

【问题讨论】:

    标签: javascript graphql nestjs typeorm


    【解决方案1】:

    您并没有等待您的事务完成,因此可能会在您的函数调用结束后引发异常并且您没有收到异常。

    等待您的交易,应该没问题。

    await getManager().transaction(async transactionalEntityManager => {
      ...
      throw 'ERROR THAT SHOULD BE CATCHED'
    }
    

    它还返回内部函数的结果,因此很有用。

    const ok = await getManager().transaction(async transactionalEntityManager => {
      await transactionalEntityManager.save<Entity>(newEntity)
      await transactionalEntityManager.save<Entity>(newEntity2)
      return 'OK'
    }
    

    【讨论】:

      猜你喜欢
      • 2019-05-09
      • 2020-03-18
      • 1970-01-01
      • 2020-07-22
      • 2022-01-21
      • 2021-11-10
      • 2017-08-27
      • 2020-07-02
      • 2016-08-07
      相关资源
      最近更新 更多