noa*_*ner 5 postgresql typeorm nestjs
我的用户和项目的多对多关系如下:
// project.entity.ts
@Entity()
export class Project extends BaseEntity {
@PrimaryGeneratedColumn()
id: number;
@Column()
name: string;
@OneToMany(type => ProjectUser, projectUser => projectUser.project)
projectUsers: ProjectUser[];
@CreateDateColumn({ type: 'timestamp', default: () => 'CURRENT_TIMESTAMP', readonly: true })
createdAt: Date;
@UpdateDateColumn({ type: 'timestamp', default: () => 'CURRENT_TIMESTAMP' })
updatedAt: Date;
@DeleteDateColumn({ type: 'timestamp' })
deletedAt: Date;
}
Run Code Online (Sandbox Code Playgroud)
// user.entity.ts
@Entity()
export class User extends BaseEntity {
@PrimaryGeneratedColumn()
id: number;
@Column()
email: string;
@Column()
password: string;
@OneToMany(type => ProjectUser, projectUser => projectUser.user)
projectUsers: ProjectUser;
@CreateDateColumn({ type: 'timestamp', default: () => 'CURRENT_TIMESTAMP', readonly: true })
createdAt: Date;
@UpdateDateColumn({ type: 'timestamp', default: () => 'CURRENT_TIMESTAMP' })
updatedAt: Date;
@DeleteDateColumn({ type: 'timestamp' })
deletedAt: Date;
}
Run Code Online (Sandbox Code Playgroud)
// project_user.entity.ts
@Entity()
export class ProjectUser extends BaseEntity{
@PrimaryGeneratedColumn()
id: number;
@Column()
projectId: number;
@Column()
userId: number;
@Column()
isUserCreator: boolean;
@ManyToOne(type => Project, project => project.projectUsers)
@JoinColumn()
project: Project;
@ManyToOne(type => User, user => user.projectUsers)
@JoinColumn()
user: User;
}
Run Code Online (Sandbox Code Playgroud)
当我尝试保存新项目时,新ProjectUser记录不会保存。
// project.service.ts
async create(project: DeepPartial<Project>): Promise<Project> {
---> project { name: 'project1', projectUsers: [{userId: 1, isUserCreator: true}]
const projectToSave = Project.create(project)
projectToSave.projectUsers = ProjectUser.create(project.projectUsers)
return await projectToSave.save();
}
Run Code Online (Sandbox Code Playgroud)
有什么想法为什么我无法将记录保存在相关表中吗?
您只创建了projectUsers实例但没有保存它们。
使用以下代码保存所有project和projectUsers:
const projectToSave = Project.create(project);
await projectToSave.save();
const projectUsers = ProjectUser.create(project.projectUsers);
projectUsers.forEach(p => p.project = projectToSave);
await projectUsers.save(projectUsers);
return projectToSave;
Run Code Online (Sandbox Code Playgroud)
或者
const projectUsers = await ProjectUser.save(ProjectUser.create(project.projectUsers));
const projectToSave = Project.create(project);
projectToSave.projectUsers = projectUsers;
return await projectToSave.save();
Run Code Online (Sandbox Code Playgroud)
另一个解决方案
您只需cascade在实体中设置选项即可自动保存。
| 归档时间: |
|
| 查看次数: |
5132 次 |
| 最近记录: |