Jesse McCormick (
https://hibernate.atlassian.net/secure/ViewProfile.jspa?accountId=557058%...
) *updated* an issue
Hibernate ORM (
https://hibernate.atlassian.net/browse/HHH?atlOrigin=eyJpIjoiMzUyZWQ5ODAx...
) / Bug (
https://hibernate.atlassian.net/browse/HHH-14005?atlOrigin=eyJpIjoiMzUyZW...
) HHH-14005 (
https://hibernate.atlassian.net/browse/HHH-14005?atlOrigin=eyJpIjoiMzUyZW...
) Saving envers audit entry causing Lazy Initialization exception for unitialized Lazy
ManyToOne relationship (
https://hibernate.atlassian.net/browse/HHH-14005?atlOrigin=eyJpIjoiMzUyZW...
)
Change By: Jesse McCormick (
https://hibernate.atlassian.net/secure/ViewProfile.jspa?accountId=557058%...
)
Updating a legacy Hibernate 4 to latest 5.4.15 version resulted in an odd exception when
saving the audit record for a record. Turning up the debugging reveals that the actual
save of the record appears to proceed correctly, and then when envers begins to save
it's audit entry, the Lazy initialization exception occurs.
Save RelatedToTaskEntity cascades to save TaskEntity, which then moves onto the Owner
entity where the exception occurs. I looked at [HHH-13191] but toggling the proxy
compliance mode didn't seem to effect it. Hibernate 5.4.1 and 5.4.10 work, it appears
to have broken in 5.4.11. Looking through the release notes, maybe [HHH-13760] is
related?
RelatedToTaskEntity
{quote}@Audited
@Entity
public class RelatedToTaskEntity extends BaseDO<Integer> \{
@javax.persistence.Column(name = "RELATED_TO_TASK_ID")
@Id
@Getter
@Setter
@SequenceGenerator(name = "RELATED_TO_TASK_ID_GENERATOR", sequenceName =
"SQ_RELATED_TO_TASK", allocationSize = 1)
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator =
"RELATED_TO_TASK_ID_GENERATOR")
private Integer relatedToTaskId;
@Getter
@Setter
@Audited(targetAuditMode = RelationTargetAuditMode.NOT_AUDITED)
@ManyToOne
@JoinColumn(name = "TASK_CD")
private TaskEntity task;{quote}
TaskEntity
{quote}@Table(name = "TASK")
@Audited
@Entity
@Inheritance(strategy = InheritanceType.JOINED)
public class TaskEntity extends BaseDO<Long> \{
@Getter
@Setter
@Column(name = "TASK_ID")
@Id
@SequenceGenerator(name = "TASK_ID_GENERATOR", sequenceName =
"SQ_TASK", allocationSize=1)
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator =
"TASK_ID_GENERATOR")
private Long id;
@Getter
@Setter
@Audited(targetAuditMode = RelationTargetAuditMode.NOT_AUDITED)
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "OWNER_CD", referencedColumnName = "USER_ID",
updatable = false, insertable = false)
private UserInfoEntity owner;
{quote}
UserInfoEntity
\ {quote}@Audited
@Table(name = "USER_INFO")
@Entity
@Immutable
public class UserInfoEntity extends BaseDO<Integer> implements Membership
\{ {quote}
@NotAudited
private static final long serialVersionUID = -6307303034600735463L;
{noformat}@Column(name = "USER_ID")
@Id
private Integer userId;{noformat}
\{/quote}
(
https://hibernate.atlassian.net/browse/HHH-14005#add-comment?atlOrigin=ey...
) Add Comment (
https://hibernate.atlassian.net/browse/HHH-14005#add-comment?atlOrigin=ey...
)
Get Jira notifications on your phone! Download the Jira Cloud app for Android (
https://play.google.com/store/apps/details?id=com.atlassian.android.jira....
) or iOS (
https://itunes.apple.com/app/apple-store/id1006972087?pt=696495&ct=Em...
) This message was sent by Atlassian Jira (v1001.0.0-SNAPSHOT#100126- sha1:99a90f9 )