2013-07-30 66 views
0

我正在使用Spring Data(JPA flavor)和Hibernate为新的Web应用程序构建数据层。我遇到的问题是@OneToMany集合没有在数据加载时填充。我试过FetchType.LAZY和FetchType.EAGER,结果没有任何变化。这些注释是否设置正确?Spring-data-jpa @OneToMany集合不填充

这里(编辑空间)的父类:

public class AppMaster implements java.io.Serializable { 

    @Id 
    @GeneratedValue 
    @Column(name="APPLICATION_ID", unique=true, nullable=false) 
    private long ApplicationId; 

    @OneToMany(cascade=CascadeType.ALL, fetch=FetchType.EAGER, mappedBy="appMaster") 
    private Set<AppAddress> addresses = new HashSet<AppAddress>(0); 

这里的子类(也编辑空间):

public class AppAddress implements java.io.Serializable { 

    @Id 
    @GeneratedValue 
    @Column(name="ADDRESS_ID", unique=true, nullable=false) 
    private long addressId; 

    @ManyToOne(fetch=FetchType.LAZY) 
    @JoinColumn(name="APPLICATION_ID", nullable=false) 
    private AppMaster appMaster; 

我的数据生成和@Before安装过程中保存JUnit测试的一部分,看起来像这样:

AppMaster table: 
    APPLICATION_ID=1 

AppAddress table: 
    ADDRESS_ID=1, APPLICATION_ID=1 
    ADDRESS_ID=2, APPLICATION_ID=1 
    ADDRESS_ID=3, APPLICATION_ID=1 
    ADDRESS_ID=4, APPLICATION_ID=1 

所以我应该可以说

AppMaster master = appMasterService.findOne(1); // Load existing record 
assertEquals(4, master.getAddresses().size()); // Loaded 4 dependent records 

但是,当我这样做,我得到这个:

java.lang.AssertionError: 
Expected :4 
Actual :0 
    at org.junit.Assert.fail(Assert.java:93) 
    at org.junit.Assert.failNotEquals(Assert.java:647) 
    at org.junit.Assert.assertEquals(Assert.java:128) 
    at org.junit.Assert.assertEquals(Assert.java:472) 
    at org.junit.Assert.assertEquals(Assert.java:456) 
    at test.service.AppAddressServiceTest.setupData(AppAddressServiceTest.java:45) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:45) 
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15) 
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:42) 
    at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:27) 
    at org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:74) 
    at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:83) 
    at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:72) 
    at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:231) 
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:47) 
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:231) 
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:60) 
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:229) 
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:50) 
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:222) 
    at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61) 
    at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:71) 
    at org.junit.runners.ParentRunner.run(ParentRunner.java:300) 
    at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:174) 
    at org.junit.runner.JUnitCore.run(JUnitCore.java:157) 
    at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:63) 

任何人都可以揭示出这个任意光?

+0

不是'mappedBy =“AppMaster”'必须是'mappedBy =“appMaster”'?因为这是AppAdress类中的字段名称。 – obecker

+0

@obecker,你说的没错 - 那是我之前编辑导致的一个错字。我已经在示例中修复了它。 (发布编辑代码的风险。)谢谢... – user1071914

回答

1

问题是原始数据在同一个事务中被创建和读取。由于数据在事务结束时从未刷新到实际的数据存储,因此JUnit测试(这是出现此问题的位置)没有任何内容可供读取。

的解决方案是HSQLDB数据库的春天测试context.xml的启动过程中创建的测试数据:

<jdbc:embedded-database id="testDataSource" type="HSQL"> 
    <jdbc:script location="database/app_schema.sql" /> 
    <jdbc:script location="database/app_data.sql" /> 
</jdbc:embedded-database> 

,当JUnit测试启动方式,很快,已经有数据存在等待阅读。

0

您是否启用了调试模式以显示sql生成?在Spring中,它是showSQL = true。看看SQL,它可能会提供一些线索。