Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/backbone.js/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
如何在NestJS中使用@AfterLoad()、@BeforeUpdate()Typeorm中的存储库_Nestjs_Typeorm - Fatal编程技术网

如何在NestJS中使用@AfterLoad()、@BeforeUpdate()Typeorm中的存储库

如何在NestJS中使用@AfterLoad()、@BeforeUpdate()Typeorm中的存储库,nestjs,typeorm,Nestjs,Typeorm,我们在nestJs中使用类型化的订阅者和监听器,并希望在AfterLoad函数中使用repository async beforeUpdate(event: UpdateEvent<any>) { const entityClassName = event.entity.constructor.name; const userRepository = await event.manager.getRepository(User);

我们在nestJs中使用类型化的订阅者和监听器,并希望在AfterLoad函数中使用repository

    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);
      }
async beforeUpdate(事件:UpdateEvent){
const entityClassName=event.entity.constructor.name;
const userRepository=wait event.manager.getRepository(用户);
const result=等待存储库
.createQueryBuilder(“用户”)
.andWhereInID(event.entity.updatedById)
.getOne();
const log=new AuditLog();
//设置字段值
log.before=event.databaseEntity;
log.after=event.entity;
log.entity=event.metadata.tableName.toString();
log.date=新日期();
log.eventType=eventType.UPDATE;
log.updatedBy={
id:result.id,
lastName:result.lastName,
phoneNumber:result.phoneNumber,
};
//设置字段值
const logRepository=wait event.manager.getRepository(AuditLog);
等待logRepository.save(日志);
}
但是repository.save()不起作用。有人能帮我吗?

可以先使用getConnection()然后使用getEntityManager(),但这不是在加载后使用存储库的好方法,因为它会创建实体的循环加载并导致项目失败。 所以不要在afterload()中使用存储库