ach*_*ahe 4 java hibernate jpa glassfish-embedded jboss-arquillian
我很难理解延迟获取,因为我在书中读到它时我不工作,他们说在延迟获取中 jpa 只会在通过 geters 访问实体时加载实体,所以我创建了一个 Arquillian 项目来测试这个概念但它不起作用。这是我的两个实体
人
package com.actionbazaar.model;
@Entity
@TableGenerator(
initialValue = 5,
name = "PERSON_SEQ",
table = "PERSON_SEQ_TABLE",
pkColumnName = "SEQ_NAME",
pkColumnValue = "PERSON",
valueColumnName = "SEQ_VALUE")
public class Person implements Serializable {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private int id;
private String fname;
private String lname;
@OneToMany(fetch = FetchType.LAZY, mappedBy = "owner", cascade = CascadeType.PERSIST)
List<Address> addresses;
//getters and setters
}
Run Code Online (Sandbox Code Playgroud)
地址
@Entity
public class Address implements Serializable {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private int id;
private String city;
private String zip;
private String street;
@ManyToOne
private Person owner;
//getters and setters
}
Run Code Online (Sandbox Code Playgroud)
我有一个使用这种方法的无状态会话 bean
public Person getFirstPerson() {
Person p = em.find(Person.class, 1);
em.detach(p);
//why this call does not create an exception
p.getAddresses().get(0);
return p;
}
Run Code Online (Sandbox Code Playgroud)
因为我在访问地址之前分离了实体,所以地址列表应该是空的,当我分离它时,它不再由实体管理器管理,所以我不应该为这个人获取地址问题是我可以获取那个地址甚至我对地址字段进行了延迟获取并在访问地址字段之前分离了实体!!!!请一些解释。
另一个测试
Person p= myStatlessSessionBean.getFirstPerson();
myOtherStalessSesionBean.moveAllPeopleToCity("NY");
if(p.getAddresses().get(0).getCity().equals("NY"))
{
system.out.prinln("person moved");
}
else {
system.out.prinln("person did not move");
} //prompts person did not move
Run Code Online (Sandbox Code Playgroud)
是的,伙计,你说得对。你在这里没有做错任何事。我刚刚打开Pro JPA 2, 2nd edition Book并发现了这个:
您正在使用glassfish-embedded这实际上是导致问题的原因。你的代码没有问题。正如上述书的作者所提到的,
一些供应商可能会尝试解决这种关系,而其他供应商可能只是抛出异常或未初始化属性。
因此,在您的情况下,关系已解决,而不是延迟加载。只需使用其他供应商实现相同的示例,您就不会遇到任何问题。这里使用 glassfish 嵌入式,lazyfetch不起作用。否则应该抛出异常,因为变量p是分离的。
这里是链接在那里我也看到这个美丽的资料片
| 归档时间: |
|
| 查看次数: |
5393 次 |
| 最近记录: |