如何在 NestJS 的 @AfterLoad(), @BeforeUpdate() Typeorm 中使用存储库
how to use repositories in @AfterLoad(), @BeforeUpdate() Typeorm in NestJS
我们在 nestJs 中使用了 typeorm 的订阅者和监听器,并希望在 AfterLoad 函数中使用存储库。
async beforeUpdate(event: UpdateEvent<any>) {
const entityClassName = event.entity.constructor.name;
const userRepository = await event.manager.getRepository(User);
const result = await repository
.createQueryBuilder('user')
.andWhereInIds(event.entity.updatedById)
.getOne();
const log = new AuditLog();
// set field values
log.before = event.databaseEntity;
log.after = event.entity;
log.entity = event.metadata.tableName.toString();
log.date = new Date();
log.eventType = EventType.UPDATE;
log.updatedBy = {
id: result.id,
lastName: result.lastName,
phoneNumber: result.phoneNumber,
};
// set field values
const logRepository = await event.manager.getRepository(AuditLog);
await logRepository.save(log);
}
但 repository.save() 不起作用。谁能帮帮我?
可以使用 getConnection(),然后使用 getEntityManager(),但这不是在加载后使用存储库的好方法,因为它会创建实体的循环加载和失败项目的 Couse。
所以不要在 afterload()
中使用存储库
我们在 nestJs 中使用了 typeorm 的订阅者和监听器,并希望在 AfterLoad 函数中使用存储库。
async beforeUpdate(event: UpdateEvent<any>) {
const entityClassName = event.entity.constructor.name;
const userRepository = await event.manager.getRepository(User);
const result = await repository
.createQueryBuilder('user')
.andWhereInIds(event.entity.updatedById)
.getOne();
const log = new AuditLog();
// set field values
log.before = event.databaseEntity;
log.after = event.entity;
log.entity = event.metadata.tableName.toString();
log.date = new Date();
log.eventType = EventType.UPDATE;
log.updatedBy = {
id: result.id,
lastName: result.lastName,
phoneNumber: result.phoneNumber,
};
// set field values
const logRepository = await event.manager.getRepository(AuditLog);
await logRepository.save(log);
}
但 repository.save() 不起作用。谁能帮帮我?
可以使用 getConnection(),然后使用 getEntityManager(),但这不是在加载后使用存储库的好方法,因为它会创建实体的循环加载和失败项目的 Couse。 所以不要在 afterload()
中使用存储库