2013-07-30 147 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,它可能會提供一些線索。