0

我有一个疑问,那就是当我们将一对多创建为双向时。我们将在子类中放置一个父类引用。

看代码。

人.java

@Entity
@Table(name="PERSON")
public class Person {
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    @Column(name="personId")
     private int id;
    @Column(name="personName")
    private String name;
    @OneToMany(cascade =CascadeType.ALL,fetch = FetchType.LAZY)
    @JoinColumn(name="personId") 
    private Set <Address> addresses;
         ....
         ....
}

地址.java

@Entity
@Table(name = "ADDRESS")
public class Address {
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    @Column(name = "addressId")
    private int id;
    @Column(name = "address",nullable=false)
    private String address;
    @ManyToOne(cascade =CascadeType.ALL)
    @JoinColumn(name="personId",nullable=false)
    private Person person;
           ....
           ....
    }

这里Person.java是父类,Address.java是子类。当我们从数据库中获取父对象时,它正在加载子类。没事。没问题。

但反之亦然。如果我们正在获取子类,它也持有父类(person)

例如:我们通过地址 id 获取地址。假设从数据库中检索到 100 个地址。

但在地址类人员变量中也保存了父(人员)对象。

我的疑问就在这里

是使用不同的 100 人的记忆 。具有相同的数据。在地址类中。?

我的道就是这样。

public List<Address> getAllAddressByPersonId(int personId) {
        List<Address> addressList =  null;
        try {
            DetachedCriteria criteria = DetachedCriteria.forClass(Address.class);
            criteria.createCriteria("person").add(Restrictions.eq("id", personId));
            addressList = getHibernateTemplate().findByCriteria(criteria);
        } catch (HibernateException e) {
            e.printStackTrace();
        } catch (DataAccessException e) {
            e.printStackTrace();
        }

        return addressList;

假设 addrssList 的大小为 100。

per =  addressList.get(0).getPerson() , 

per 1 = addressList.get(1).getPerson(),

per2 = addressList.get(2).getPerson(),

....

per99 =  addressList.get(99).getPerson(). 

这里per1, per2 .... 和 per 99使用相同或不同的内存。

如果相同就可以了。否则它可能会导致更多内存利用率的任何执行问题。?

请帮助...

4

1 回答 1

0

Hibernate 进行身份检查。一个休眠会话仅包含具有相同 ID 的对象的单个实例。因此,如果 per, per1,...per99 是一个人,那么您将拥有一个对象。否则 - 不同的对象。

于 2011-10-20T13:25:43.313 回答