嵌入式 AttributeOverride 更新不起作用
Embedded AttributeOverride on update not working
我的实体嵌入了两个 ModelId
类,其中一个是 EmbeddedId
,另一个引用了另一个实体。
@Entity
public class Report implements Serializable {
@EmbeddedId
private final ModelId id;
@AttributeOverride(name = "id", column = @Column(name = "scheme_id")
@Embedded
private ModelId schemeId;
public void changeScheme(ModelId schemeId) {
this.schemeId = schemeId;
}
}
@Embeddable
public class ModelId implements Serializable {
private Integer id;
}
我可以插入和selectReport
但是当我更新 字段 schemeId
我得到:
org.eclipse.persistence.exceptions.ValidationException
Exception Description: The attribute [id] of class [mypackage.ModelId] is mapped
to a primary key column in the database. Updates are not allowed.
我使用 GlassFish 4.1 和 EclipseLink 2.5。
我是不是遗漏了什么或者是 EclipseLink 错误?
问题是只有id
是主键,schemeId
是外键。当我将 schemeId
更改为 association 时,它 工作正常:
@ManyToOne
@JoinColumn(name = "scheme_id", referencedColumnName = "id")
private Scheme scheme;
public void changeScheme(Scheme scheme) {
this.scheme = scheme;
}
我一直在使用许多注释组合进行测试,并且在 GF4.0 和 EclipseLink 2.6 中也得到了相同的结果。
EclipseLink 似乎在更新期间忽略了 @AttributeOverride
,并将内部 schemeId.id
与 id.id
混合在一起。
由于异常说明您正在修改主键,因此 Eclipselink 不允许这样做。
两个可能的选择是:
1)删除旧实体并使用新主键创建新实体。
2) 引入不同的属性定义为主键,并对这两个字段提供唯一约束。
我们遇到了同样的问题。这个缺陷似乎被 eclipselink 的一个现有错误所覆盖(针对版本 2.6.0,我仍然在 2.6.3 中看到这个问题):
https://bugs.eclipse.org/bugs/show_bug.cgi?id=477638
似乎还没有任何 activity,所以与此同时我将 @EmbeddedId
更改为 @Embedded
并添加了一个私有主键,像这样:
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private int privateId;
我还为以前属于主键的属性添加了复合唯一约束。我还必须更改 EntityManager.find(dataType, id)
调用以执行查询。希望对您有所帮助。
我的实体嵌入了两个 ModelId
类,其中一个是 EmbeddedId
,另一个引用了另一个实体。
@Entity
public class Report implements Serializable {
@EmbeddedId
private final ModelId id;
@AttributeOverride(name = "id", column = @Column(name = "scheme_id")
@Embedded
private ModelId schemeId;
public void changeScheme(ModelId schemeId) {
this.schemeId = schemeId;
}
}
@Embeddable
public class ModelId implements Serializable {
private Integer id;
}
我可以插入和selectReport
但是当我更新 字段 schemeId
我得到:
org.eclipse.persistence.exceptions.ValidationException
Exception Description: The attribute [id] of class [mypackage.ModelId] is mapped
to a primary key column in the database. Updates are not allowed.
我使用 GlassFish 4.1 和 EclipseLink 2.5。
我是不是遗漏了什么或者是 EclipseLink 错误?
问题是只有id
是主键,schemeId
是外键。当我将 schemeId
更改为 association 时,它 工作正常:
@ManyToOne
@JoinColumn(name = "scheme_id", referencedColumnName = "id")
private Scheme scheme;
public void changeScheme(Scheme scheme) {
this.scheme = scheme;
}
我一直在使用许多注释组合进行测试,并且在 GF4.0 和 EclipseLink 2.6 中也得到了相同的结果。
EclipseLink 似乎在更新期间忽略了 @AttributeOverride
,并将内部 schemeId.id
与 id.id
混合在一起。
由于异常说明您正在修改主键,因此 Eclipselink 不允许这样做。 两个可能的选择是: 1)删除旧实体并使用新主键创建新实体。 2) 引入不同的属性定义为主键,并对这两个字段提供唯一约束。
我们遇到了同样的问题。这个缺陷似乎被 eclipselink 的一个现有错误所覆盖(针对版本 2.6.0,我仍然在 2.6.3 中看到这个问题):
https://bugs.eclipse.org/bugs/show_bug.cgi?id=477638
似乎还没有任何 activity,所以与此同时我将 @EmbeddedId
更改为 @Embedded
并添加了一个私有主键,像这样:
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private int privateId;
我还为以前属于主键的属性添加了复合唯一约束。我还必须更改 EntityManager.find(dataType, id)
调用以执行查询。希望对您有所帮助。