首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Spring-data-jpa @OneToMany集合未填充

Spring-data-jpa @OneToMany集合未填充
EN

Stack Overflow用户
提问于 2013-07-30 16:18:14
回答 2查看 2.5K关注 0票数 1

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

下面是父类(为空间编辑):

代码语言:javascript
复制
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);

下面是子类(也是为空间编辑的):

代码语言:javascript
复制
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测试的@ part安装部分期间生成和保存的,如下所示:

代码语言:javascript
复制
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

所以我应该可以说

代码语言:javascript
复制
AppMaster master = appMasterService.findOne(1);  // Load existing record
assertEquals(4, master.getAddresses().size());   //  Loaded 4 dependent records

但当我这么做的时候我得到了这个:

代码语言:javascript
复制
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)

有人能解释一下这件事吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-08-07 19:59:21

问题是原始数据是在同一个事务中创建和读取的。由于数据从未在事务结束时被刷新到实际的数据存储区,所以JUnit测试(出现此问题的地方)没有什么可读取的。

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

代码语言:javascript
复制
<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测试启动时,预览,已经有数据在那里,等待读取。

票数 4
EN

Stack Overflow用户

发布于 2013-07-30 17:20:10

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

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17952285

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档