作为响应在子模型中获取所有父数据

时间:2019-06-10 09:44:29

标签: spring spring-boot jpa spring-data-jpa jpa-2.1

我有两个表email_draft和email_draft_history。 email_draft是一个父表,而email_draft可以有多个email_draft_id。当尝试获取数据时,我得到了所有父数据和子数据,但是在子数据中,我也得到了父数据。

我首先尝试了fetch.lazy,但是它给了我一些错误,因此我必须将其标记为@JsonIgnore。我也必须从tostring()中删除子类对象引用。

   @Entity
   @NoArgsConstructor
   @AllArgsConstructor
   @Table(name = "email_draft", schema = "ssdapiadm")
   @JsonIgnoreProperties(ignoreUnknown = true)
   public class EmailDraft implements Serializable {

private static final long serialVersionUID = 1L;

@Id
@GeneratedValue(generator = "email_draft_ed_id_seq", strategy = GenerationType.SEQUENCE)
@SequenceGenerator(name = "email_draft_ed_id_seq", sequenceName = "ssdapiadm.email_draft_ed_id_seq", allocationSize = 1)
@Column(name = "ed_id")
private Integer emailDraftId;

@Column(name = "email_to")
private String emailTo;

@Column(name = "cc")
private String cc;

@Column(name = "bcc")
private String bcc;

@Column(name = "subject")
private String subject;

@Column(name = "body")
@Lob
@Type(type = "org.hibernate.type.BinaryType")
private byte[] body;

@Column(name = "created_by")
private Integer createdBy;

@Column(name = "updated_by")
private Integer updatedBy;

@Column(name = "source")
private String source;

@Column(name = "created_date")
private LocalDateTime createdDate;

@Column(name = "updated_date")
private LocalDateTime updatedDate;

@Column(name = "draft_status")
private String draftStatus;

@Column(name = "client_ppl_code")
private Integer clientPplCode;

@Column(name = "assigned_to")
private Integer assignedTo;

@Column(name = "deleted_BY")
private Integer deletedBy;

@Column(name = "email_sent_by")
private Integer emailSentBy;

@Column(name = "deleted_date")
private LocalDateTime deletedDate;

@Column(name = "email_sent_date")
private LocalDateTime emailSentDate;

@Column(name = "is_joint_Consultation")
private Boolean isjointConsultation;

@Column(name = "comments")
private String comments;

@Column(name = "version_id")
private Integer versionId;

@OneToMany(fetch = FetchType.LAZY, cascade = CascadeType.ALL,mappedBy="emailDraft")
@JsonIgnore
private List<Activity> activity;


public String getEmailTo() {
    return emailTo;
}

public void setEmailTo(String emailTo) {
    this.emailTo = emailTo;
}

public String getCc() {
    return cc;
}

public void setCc(String cc) {
    this.cc = cc;
}

public String getSubject() {
    return subject;
}

public void setSubject(String subject) {
    this.subject = subject;
}

public Integer getCreatedBy() {
    return createdBy;
}

public void setCreatedBy(Integer createdBy) {
    this.createdBy = createdBy;
}

public Integer getUpdatedBy() {
    return updatedBy;
}

public void setUpdatedBy(Integer updatedBy) {
    this.updatedBy = updatedBy;
}

public String getSource() {
    return source;
}

public void setSource(String source) {
    this.source = source;
}

public LocalDateTime getCreatedDate() {
    return createdDate;
}

public void setCreatedDate(LocalDateTime createdDate) {
    this.createdDate = createdDate;
}

public LocalDateTime getUpdatedDate() {
    return updatedDate;
}

public void setUpdatedDate(LocalDateTime updatedDate) {
    this.updatedDate = updatedDate;
}

public String getDraftStatus() {
    return draftStatus;
}

public void setDraftStatus(String draftStatus) {
    this.draftStatus = draftStatus;
}

public Integer getClientPplCode() {
    return clientPplCode;
}

public void setClientPplCode(Integer clientPplCode) {
    this.clientPplCode = clientPplCode;
}

public static long getSerialversionuid() {
    return serialVersionUID;
}

public String getBcc() {
    return bcc;
}

public void setBcc(String bcc) {
    this.bcc = bcc;
}

public Integer getAssignedTo() {
    return assignedTo;
}

public void setAssignedTo(Integer assignedTo) {
    this.assignedTo = assignedTo;
}

public byte[] getBody() {
    return body;
}

public void setBody(byte[] body) {
    this.body = body;
}

public Integer getDeletedBy() {
    return deletedBy;
}

public void setDeletedBy(Integer deletedBy) {
    this.deletedBy = deletedBy;
}

public Integer getEmailSentBy() {
    return emailSentBy;
}

public void setEmailSentBy(Integer emailSentBy) {
    this.emailSentBy = emailSentBy;
}

public LocalDateTime getDeletedDate() {
    return deletedDate;
}

public void setDeletedDate(LocalDateTime deletedDate) {
    this.deletedDate = deletedDate;
}

public LocalDateTime getEmailSentDate() {
    return emailSentDate;
}

public void setEmailSentDate(LocalDateTime emailSentDate) {
    this.emailSentDate = emailSentDate;
}

public String getComments() {
    return comments;
}

public void setComments(String comments) {
    this.comments = comments;
}

public Integer getEmailDraftId() {
    return emailDraftId;
}

public void setEmailDraftId(Integer emailDraftId) {
    this.emailDraftId = emailDraftId;
}

public Boolean getIsjointConsultation() {
    return isjointConsultation;
}

public void setIsjointConsultation(Boolean isjointConsultation) {
    this.isjointConsultation = isjointConsultation;
}

public Integer getVersionId() {
    return versionId;
}

public void setVersionId(Integer versionId) {
    this.versionId = versionId;
}

public List<Activity> getActivity() {
    return activity;
}

public void setActivity(List<Activity> activity) {
    this.activity = activity;
}

@Override
public String toString() {
    return "EmailDraft [emailDraftId=" + emailDraftId + ", emailTo=" + emailTo + ", cc=" + cc + ", bcc=" + bcc
            + ", subject=" + subject + ", body=" + Arrays.toString(body) + ", createdBy=" + createdBy
            + ", updatedBy=" + updatedBy + ", source=" + source + ", createdDate=" + createdDate + ", updatedDate="
            + updatedDate + ", draftStatus=" + draftStatus + ", clientPplCode=" + clientPplCode + ", assignedTo="
            + assignedTo + ", deletedBy=" + deletedBy + ", emailSentBy=" + emailSentBy + ", deletedDate="
            + deletedDate + ", emailSentDate=" + emailSentDate + ", isjointConsultation=" + isjointConsultation
            + ", comments=" + comments + ", versionId=" + versionId + "]";
}
    }


    @Entity
    @Table(name = "email_draft_activity", schema = "ssdapiadm")
    @JsonIgnoreProperties(ignoreUnknown = true)
    public class Activity implements Serializable {

private static final long serialVersionUID = 1L;

@Id
@GeneratedValue(generator = "email_draft_activity_ed_activity_id_seq", strategy = GenerationType.SEQUENCE)
@SequenceGenerator(name = "email_draft_activity_ed_activity_id_seq", sequenceName = "ssdapiadm.email_draft_activity_ed_activity_id_seq", allocationSize = 1)
@Column(name = "ed_activity_id")
private Integer emaildraftActivityId;

@Column(name = "activity_type")
private String activityType;

@Column(name = "activity_name")
private String activityName;

@Column(name = "reason_code")
private String reasonCode;

@Column(name = "assigned_to")
private Integer assignedTo;

@ManyToOne(cascade = {CascadeType.MERGE,CascadeType.PERSIST,CascadeType.REFRESH},optional=false,fetch=FetchType.EAGER)
@JoinColumn(name = "ed_id")
private EmailDraft emailDraft;

public static long getSerialversionuid() {
    return serialVersionUID;
}

public Integer getEmaildraftActivityId() {
    return emaildraftActivityId;
}

public String getActivityType() {
    return activityType;
}

public String getActivityName() {
    return activityName;
}

public String getReasonCode() {
    return reasonCode;
}

public Integer getAssignedTo() {
    return assignedTo;
}

public EmailDraft getEmailDraft() {
    return emailDraft;
}


public void setEmaildraftActivityId(Integer emaildraftActivityId) {
    this.emaildraftActivityId = emaildraftActivityId;
}

public void setActivityType(String activityType) {
    this.activityType = activityType;
}

public void setActivityName(String activityName) {
    this.activityName = activityName;
}

public void setReasonCode(String reasonCode) {
    this.reasonCode = reasonCode;
}

public void setAssignedTo(Integer assignedTo) {
    this.assignedTo = assignedTo;
}

public void setEmailDraft(EmailDraft emailDraft) {
    this.emailDraft = emailDraft;
}



@Override
public String toString() {
    return "Activity [emaildraftActivityId=" + emaildraftActivityId + ", activityType=" + activityType
            + ", activityName=" + activityName + ", reasonCode=" + reasonCode + ", assignedTo=" + assignedTo
            + ", emailDraft=" + emailDraft + ", emailDraftId=]";
}
    }

以下是我的服务班级。 :-

@Override
public EmailDraftModel fetchAllEmailDraftByEmailDraftId(Integer emailDraftid) throws Exception {
    EmailDraft draft = finadAllEmailDraft(emailDraftid);
    EmailDraftModel draftModel = null;
    if(draft != null){
        draftModel = new EmailDraftModel();
        convertEmailDraftToEmailDraftModel(draft, draftModel);
        checkAndSetNanoSecondsinEmailDraft(draftModel);
    }
    return draftModel;
}

private void convertEmailDraftToEmailDraftModel(EmailDraft draft, EmailDraftModel draftModel) {
    BeanUtils.copyProperties(draft, draftModel);
    if (!CollectionUtils.isEmpty(draft.getActivity())) {            draftModel.setActivity(draft.getActivity().stream().map(activity -> EntityMapperUtil.mapSourceObjectToTargetClass(activity, ActivityModel.class)).collect(Collectors.toList()));
    }
}

我得到回应的json:-

{
    "emailDraftId": 233,
    "emailTo": "something@something.com",
    "cc": "something@something.com",
    "bcc": "Assurance@labsomething.com>",
    "subject": "test",
    "body": "WWZEdGxVY0tRLnBuZyIgYWx0PSJpbWciIHdpZHRoPSI4MDAiIGhlaWdodD0iMzg2IiAvPjxiciAvPgo8ZGl2PiZuYnNwOzwvZGl2Pgo8L2Rpdj4KPC9ib2R5Pgo8L2h0bWw+",
    "createdBy": 12345,
    "updatedBy": 12345,
    "source": "postcall",
    "createdDate": "2019-06-06T08:52:13.103",
    "updatedDate": "2019-06-06T12:08:53.712",
    "draftStatus": "open",
    "clientPplCode": 12345,
    "assignedTo": null,
    "deletedBy": null,
    "emailSentBy": null,
    "deletedDate": null,
    "emailSentDate": null,
    "isDeleted": null,
    "isjointConsultation": false,
    "comments": "comment added",
    "activity": [{
        "emaildraftActivityId": 24,
        "activityType": "abcd",
        "activityName": "Saved Follow Up with Activity",
        "reasonCode": "Consultation - Phone",
        "assignedTo": 58426,
        "emailDraft": {
            "emailDraftId": 233,
            "emailTo": "something@something.com",
            "cc": "something@something.com",
            "bcc": "Assurance@something.com>",
            "subject": "test",
            "body": "2Pgo8L2Rpdj4KPC9ib2R5Pgo8L2h0bWw+",
            "createdBy": 12345,
            "updatedBy": 12345,
            "source": "rhyds",
            "createdDate": "2019-06-06T08:52:13.103",
            "updatedDate": "2019-06-06T12:08:53.712",
            "draftStatus": "open",
            "clientPplCode": 12345,
            "assignedTo": null,
            "deletedBy": null,
            "emailSentBy": null,
            "deletedDate": null,
            "emailSentDate": null,
            "isjointConsultation": false,
            "comments": "comment added",
            "versionId": 3
        },
        "emailDraftId": 3
    }, {
        "emaildraftActivityId": 25,
        "activityType": "abcd",
        "activityName": "Saved Follow Up with Activity",
        "reasonCode": "Consultation - Phone",
        "assignedTo": 58426,
        "emailDraft": {
            "emailDraftId": 233,
            "emailTo": "something@something.com",
            "cc": "something@something.com",
            "bcc": "Assurance@labsomething.com>",
            "subject": "test",
            "body": "PC9ib2R5Pgo8L2h0bWw+",
            "createdBy": 12345,
            "updatedBy": 12345,
            "source": "dfgjrfy",
            "createdDate": "2019-06-06T08:52:13.103",
            "updatedDate": "2019-06-06T12:08:53.712",
            "draftStatus": "open",
            "clientPplCode": 12345,
            "assignedTo": null,
            "deletedBy": null,
            "emailSentBy": null,
            "deletedDate": null,
            "emailSentDate": null,
            "isjointConsultation": false,
            "comments": "comment added",
            "versionId": 3
        },
        "emailDraftId": 3
    }]

}

我想先获取父数据,如果需要,则可以获取子数据。在子数据中,我只想获取子表条目。

我是JPA的新手,所以我想我在这里错过了一些东西。

0 个答案:

没有答案