- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在使用 EclipseLink 2.4.1 和 JPA 2.0。在我的示例中,我有以下类定义:
@Entity
public class Shepard {
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
@Column(name = "id")
private Long id;
@OneToMany(mappedBy = "shepard", cascade = CascadeType.ALL, fetch = FetchType.LAZY)
private List<Sheep> sheeps;
public void addSheep(Sheep sheep) {
if (sheep != null) {
if (sheeps == null) {
sheeps = new ArrayList<>();
}
if (!sheeps.contains(sheep)) {
sheeps.add(sheep);
}
}
}
}
@Entity
public class Sheep {
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
@Column(name = "id")
private Long id;
@Column(name = "name")
private String name;
@ManyToOne(fetch = FetchType.EAGER, optional = false)
@JoinColumn(name="shepard_id")
private Shepard shepard;
public Sheep(Shepard shepard, String name) {
this.shepard = shepard;
this.name = name;
shepard.addSheep(this);
}
}
现在,当我编写 Junit 测试并执行以下操作时。请注意,Sheep 构造函数调用 Shepard.addSheep(Sheep)!
EntityManagerFactory emf = Persistence.createEntityManagerFactory("data");
EnttyManager em = emf.createEntityManager();
Shepard shepard = new Shepard();
// I Persist Shepard
em.getTransaction().begin();
em.persist(shepard);
em.getTransaction().commit();
// II Persist Tilda
Sheep tilda = new Sheep(shepard, "Tilda");
em.getTransaction().begin();
em.persist(tilda);
em.getTransaction().commit();
// III Persist Martha via Shepard
Sheep martha = new Sheep(shepard, "Martha");
em.getTransaction().begin();
em.merge(shepard);
em.getTransaction().commit();
然后对 Sheep's 进行命名查询,我得到了“Tilda”的重复条目!
这不会发生,当我编码时
em.persist(martha);
改为作为最后一个实体管理器访问权限。
分析调试输出,我可以看到在II 之后有一个 [id=1] 的 Shepard 对象和一个 [id=1] 的 Sheep 对象。在 III 之前和之后,Shepard 持有两个关于 Sheeps 的引用文献,之前是 [id=1] 是 Tilda,[id=null] 是 Martha。在 III 之后,Shepard 持有两份关于绵羊的引用资料,Tilda 的 [id=2] 和 Martha 的 [id=3]。
从 EclipseLink 调试输出中,我可以看到 III 向 Sheep 表发出了两个 插入语句。在数据库中最终有 三个 羊条目,其 ID 如上所列。
此外,我得到以下错误:
[EL Warning]: 2013-06-21 09:53:26.631--UnitOfWork(221387686)--Thread(Thread[main,5,main])--Exception [EclipseLink-7251] (Eclipse Persistence Services - 2.4.1.v20121003-ad44345): org.eclipse.persistence.exceptions.ValidationException
Exception Description: The attribute [id] of class [Sheep] is mapped to a primary key column in the database. Updates are not allowed.
这是 EclipseLink 的错误吗?或者我在这里做错了什么?
最佳答案
您不需要调用 merge(),因为 shepard 已经是一个托管对象。合并适用于分离/序列化的对象,而不是托管对象。如果你在 Sheep 上有一个 cascade persist,那么你不需要做任何事情,只需调用 commit。
但是,调用 merge() 应该不会引起任何问题,所以这很奇怪。如果您可以在测试中重现问题,请记录错误。您可能还想尝试 2.5 版本,看看它是否已修复。
我的猜测是制作 OneToMany EAGER 可能会解决这个问题。此外,如果您为每个事务创建一个新的 EntityManager,那么您就不会遇到这个问题(前提是您在这两种情况下都调用了合并)。
关于java - EclipseLink 以一对多关系生成重复条目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17217080/
我主要根据 EclipseLink 网站上的教程编写了以下代码: Partner p = new Partner(); p.setId(1); p.setKey("a");
我主要根据 EclipseLink 网站上的教程编写了以下代码: Partner p = new Partner(); p.setId(1); p.setKey("a");
我目前尝试在 WebLogic Server 12c 中运行 Docx4j。 WebLogic Server 12c 随 EclipseLink 2.3.2 一起提供。 有一个类似的Post描述不幸的
例如,在 EclipseLink 中使用 @AdditionalCriteria 很容易过滤掉软删除的实体,但是有什么方法可以在执行特定查询之前暂时禁用它? 最佳答案 是的,这是可能的,有一个简单的解
我们正在考虑从 Oracle Kodo JDO 迁移到 TopLink 11g JPA。但我发现 EclipseLink 确实存在,而且似乎更应该感谢 Toplink。目前关于它的维基文章指出 Ecl
我正在使用 h2 为使用 Eclipselink、Arquillian 和 Weblogic 12.1.1 的应用程序设置集成测试 这是我的实体: @Entity @Table(name = "AFI
我正在创建一个简单的应用程序,我将在其中使用对象关系映射。我听说过 eclipselink JPA 并做了一个 POC。看起来就像在我本地工作。 我脑子里有两个问题。 eclipselink 与环境有
加载有什么区别: 对比 我可以看到在 maven“EclipseLink”中命名的 Eclipselink 比另一个有更多的类和实用程序......例如目标数据库: org.eclipse.per
我的目标是学习 JavaEE,还有什么比参与项目更好的方法呢?因此,我开始创建一个股票市场模拟 Web 应用程序。当然,一个人拥有一些由公司代码 (company_id) 标识的股票以及所拥有的相关股
Bundle org.eclipse.persistence.extension_2.7.0.qualifier.jar(我安装到 osgi 框架)包含类 org.eclipse.persistenc
我正在尝试向我的 Spring 数据 jpa 存储库添加 Multi-Tenancy 支持。我想为每个请求动态设置租户 ID,但它不适用于自定义查找器 查找* 存储库上的方法。 我已遵循此指南:htt
我使用 Spring Data JPA 和 EclipseLink 2.5.2 作为我的 JPA 提供程序。我使用的数据库是 PostgreSQL。我有一个具有自动递增序列号的表,如下所示: CREA
我无法在单元测试中找到 ecbDB JTA 数据源。 对于 RESOURCE_LOCAL,相同的 persistence.xml 工作。只有在 EJB 容器内,它才无法定位 JTA 数据源。 执行单元
我收到一条错误消息: 异常[EclipseLink-6004] ...对象bla不是来自这个UnitOfWork对象空间,而是来自父 session 的对象空间。该对象从未在此UnitOfWork中注
在将我的 jpa 项目部署到 Wildfly 服务器时,我收到以下警告: The collection of metamodel types is empty. Model classes may n
我定义了一些实体,现在想生成表。 我使用Eclipselink 2.5(JPA 2.1)和Glassfish 4.0,我的程序使用JKD7。 当我构建应用程序时,会显示以下消息: warning: S
我使用的是最新的 EclipseLink 版本和 MySQL 5.5(表类型 InnoDB)。我一次插入大约 30900 条记录(也可能更多)。问题是,插入性能很差:插入所有记录大约需要 22 秒(与
我在持久化实体并在持久化发生后获取 id 时遇到了问题。我可以看到数据是在数据库中创建的,具有正确的 id,但对象处的 id 仍然为 null。 这是我的实体: @Entity public clas
我使用 eclipselink 2.6.3,我需要确切地知道连接池是否由 Eclipselink 创建和使用。 如果persistence.xml我有如下设置 但是,这两种情况的日志是相同的
我正在使用 EclipseLink,并将“eclipselink.ddl-generation”属性设置为“create-tables”。创建的表中列的顺序似乎是随机的。我想要特定顺序的列 - 字段在
我是一名优秀的程序员,十分优秀!