Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/324.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java Spring数据jpa@OneToMany集合未填充_Java_Hibernate_Jpa_Spring Data - Fatal编程技术网

Java Spring数据jpa@OneToMany集合未填充

Java Spring数据jpa@OneToMany集合未填充,java,hibernate,jpa,spring-data,Java,Hibernate,Jpa,Spring Data,我正在使用Spring数据(JPA风格)和Hibernate为一个新的web应用程序构建数据层。我对@OneToMany集合在数据加载时未填充有问题。我尝试了FetchType.LAZY和FetchType.EAGER,结果没有变化。这些注释设置正确吗 这是父类(为空间编辑): 我的数据是在Junit测试的@Before setup部分生成和保存的,如下所示: AppMaster table: APPLICATION_ID=1 AppAddress table: ADDRE

我正在使用Spring数据(JPA风格)和Hibernate为一个新的web应用程序构建数据层。我对@OneToMany集合在数据加载时未填充有问题。我尝试了FetchType.LAZY和FetchType.EAGER,结果没有变化。这些注释设置正确吗

这是父类(为空间编辑):

我的数据是在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)

有人能解释一下吗?

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

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

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

解决方案是在spring test context.xml中启动HSQLDB数据库期间创建测试数据:

<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测试启动时,presto中已经有数据等待读取

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

解决方案是在spring test context.xml中启动HSQLDB数据库期间创建测试数据:

<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测试启动时,presto中已经有数据等待读取

mappedBy=“AppMaster”
是否必须是
mappedBy=“AppMaster”
?因为这是AppAddress类中的字段名。@obecker,你完全正确-这是我以前编辑时造成的打字错误。我已经在示例中修复了它。(发布修订代码的风险。)谢谢……难道不必是
mappedBy=“AppMaster”
吗?因为这是AppAddress类中的字段名。@obecker,你完全正确-这是我以前编辑时造成的打字错误。我已经在示例中修复了它。(发布修订代码的风险)谢谢。。。
<jdbc:embedded-database id="testDataSource" type="HSQL">
    <jdbc:script location="database/app_schema.sql" />
    <jdbc:script location="database/app_data.sql" />
</jdbc:embedded-database>