前两天看了点OA的视频,其中的前二十来集都是在复习Hibernate,很熟悉也很轻松,当然这都是因为有了基础了。不过复习到一个属性inverse的时候,我又把代码实现了一次,主要是觉得挺好。不多说:
下面是对应inverse属性设置以及结果的简单介绍。
inverse=true的含义:由双向关联另一方维护该关联,己方不维护该关联(只能进行查询操作)。在上述代码中,由Person方维护该<many-to-many>关系,示例代码如下(以向Person参与的Event中加入新的Event为例):
Inverse:负责控制关系,默认为false,也就是关系的两端都能控制,但这样会造成一些问题,更新的时候会因为两端都控制关系,于是重复更新。一般来说有一端要设为true。
要注意的一点:在双向关联的关系中,映射的column(和table)的值要一致(即要用相同的表名和列名),不然设置为inverse="true"的这方将失去这个双向关系,而变成了一个单向关联。
我的实验是一张表,不过关系也是一对多,多对一。对于实验中的查询sql语句查询的是parent表。(注意:parent和children不是表名而是一端和多端)
当children属性的inverse设置为true时,执行update parent 语句时生成sql语句:
Hibernate: updatet_organization set name=?, sn=?, description=?, pid=? where id=?
当children属性的inverse设置为false时,执行update parent 语句时生成sql语句:
Hibernate: updatet_organization set name=?, sn=?, description=?, pid=? where id=?
Hibernate: updatet_organization set pid=null where pid=?
参考网址:
http://blog.csdn.net/leader_lx/article/details/2774137
下面的这段代码是更新表的,与inverse属性介绍关系不大,仅供参考。
public void testUpdateOrg() {
Session session = null;
try {
session = HibernateUtils.getSession();
session.beginTransaction();
Organization org1 = new Organization();
org1.setId(1);
org1.setName("父机构");
session.update(org1);
session.getTransaction().commit();
}catch(Exceptione) {
e.printStackTrace();
session.getTransaction().rollback();
}finally {
HibernateUtils.closeSession(session);
}
}