1

Spring Data (JPA フレーバー) と Hibernate を使用して、新しい Web アプリのデータ層を構築しています。@OneToMany コレクションがデータの読み込み時に読み込まれないという問題があります。FetchType.LAZY と FetchType.EAGER を試しましたが、結果は変わりませんでした。これらの注釈は正しく設定されていますか?

親クラスは次のとおりです(スペースのために編集されています):

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;

私のデータは、Junit テストの @Before setup 部分で生成および保存され、次のようになります。

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)

誰でもこれに光を当てることができますか?

4

2 に答える 2

0

生成されたSQLを表示するためにデバッグモードを有効にしましたか? Spring では、showSQL=true です。SQL を見てください。いくつかの手がかりが得られるかもしれません。

于 2013-07-30T17:20:10.840 に答える