如何使用 org.mapstruct 框架映射一对多关系?
DTO 类:
@Data
public class ScheduledJobDTO {
private String jobName;
private String jobGroup;
private String jobClass;
private String cronExpression;
private Boolean cronJob;
private Long repeatTime;
private Integer repeatCount;
private Set<ScheduledJobParamsDTO> paramtersDTOs;
}
@Data
@EqualsAndHashCode
public class ScheduledJobParamsDTO {
String name;
String value;
}
域类 -
@Data
@Entity
@Table(name = "scheduled_job")
public class ScheduledJob {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@Column(name = "job_name")
private String jobName;
@Column(name = "job_group")
private String jobGroup;
@Column(name = "job_class")
private String jobClass;
@Column(name = "cron_expression")
private String cronExpression;
@Column(name = "is_cron_job")
private Boolean cronJob;
@Column(name = "repeat_time")
private Long repeatTime;
@Column(name = "repeat_count")
private Integer repeatCount;
@Column(name = "trigger_start_date")
private LocalDate triggerStartDate;
@Column(name = "trigger_end_date")
private LocalDate triggerEndDate;
@Column(name = "created_at")
private LocalDate createdAt;
@Column(name = "modified_at")
private LocalDate modifiedAt;
@Column(name = "is_active")
private Boolean active;
@OneToMany(mappedBy = "scheduledJob")
private Set<ScheduledJobParams> parameters;
}
@Data
@Entity
@Table(name = "scheduled_job_params")
@EqualsAndHashCode
public class ScheduledJobParams {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
Long id;
@ManyToOne(fetch = FetchType.LAZY, optional = false)
@JoinColumn(name = "scheduled_job_id", nullable = false)
ScheduledJob scheduledJob;
String name;
String value;
}
映射器类 -
@Mapping(source = ".", target = ".")
@Mapping(source = "paramtersDTOs", target = "parameters")
ScheduledJob mapToDomain(ScheduledJobDTO scheduledJobDTO);
现在,上面的映射器正在映射 ScheduledJob 和 ScheduledJobParams,但 ScheduledJobParams 有 ScheduledJob 的引用。
如何将参考 ScheduledJob 映射到 ScheduledJobParams?