我在NestJS / Typeorm中有一个类似的自定义存储库类:
import { Repository, EntityRepository, getConnection } from 'typeorm';
import { RefreshToken } from './refresh-token.entity';
import { User } from './user.entity';
import { InternalServerErrorException } from '@nestjs/common';
@EntityRepository(RefreshToken)
export class RefreshTokenRepository extends Repository<RefreshToken> {
async refreshToken({ token, user }: RefreshToken): Promise<RefreshToken> {
const connection = getConnection();
const queryRunner = connection.createQueryRunner();
// establish real database connection using our new query runner
await queryRunner.connect();
// lets now open a new transaction:
await queryRunner.startTransaction();
try {
// execute some operations on this transaction:
await queryRunner.manager.delete(RefreshToken, { token });
const refreshToken = await queryRunner.manager.save(
this.buildToken(user),
);
// commit transaction now:
await queryRunner.commitTransaction();
return refreshToken;
} catch (err) {
// since we have errors lets rollback changes we made
await queryRunner.rollbackTransaction();
} finally {
// you need to release query runner which is manually created:
await queryRunner.release();
}
}
}
请问与我在refreshToken()
方法中进行交易的方式是否不同?因为建立连接感觉很糟糕,而且与NestJS的工作方式不相适应。
谢谢。
答案 0 :(得分:2)
您可以使用官方集成(软件包@nestjs/typeorm
),以使您的代码无需关心与数据库(official documentation)的连接。
使用TypeOrmModule
(@nestjs/typeorm
),可以创建(并导入)一个动态模块,该模块负责建立与数据库的连接。
@Module({
imports: [
TypeOrmModule.forRoot({
type: 'mysql',
host: 'localhost',
port: 3306,
username: 'root',
password: 'root',
database: 'test',
entities: [],
synchronize: true,
}),
],
})
export class AppModule {}
然后,您无需关心存储库代码中的连接。
如果您已经使用“原始” TypeORM创建了连接(例如,当您的应用启动时),那么Repository
已经知道如何使用它。您可以直接执行以下操作:
try {
const refreshToken = await this.manager.transaction(async entityManager => {
await entityManager.delete(RefreshToken, { token });
return entityManager.save(RefreshToken, this.buildToken(user));
});
// commit done: use refreshToken here
} catch (error) {
// rollback done: handle error here
}
您不能直接从存储库启动事务,但是可以访问(公共API)其管理器来启动事务。它提供了一个实体管理器, *必须用于所有交易操作。