· 双击“generate-hbm”任务,会发现在包中产生了Room.hbm.xml和User.hbm.xml文件,在src目录下会多了一个hibernate.cfg.xml文件,如果没有,按F5键刷新一下。
· 看看Room类的映射文件中的有关一对多关联部分:
<set
name="users"
table="T_User"
lazy="false"
inverse="false"
cascade="all"
sort="unsorted"
>
<key
column="Room_ID"
>
</key>
<one-to-many
class="javamxj.hibernate.association.one2many.User"
/>
</set>
· 上面的
lazy="false"表示不采用延迟加载,
inverse="false"表示主控方在Room端,这些属性都是XDoclet默认生成的,以后还会提到的。
· 运行MySql服务器,然后双击“schemaexport”任务,在项目根目录下,会产生一个“schema-export.sql”文件。
· 切换到数据库中,会发现已经自动产生了数据表T_Room和T_User。
4. 测试程序
· 好了,在包javamxj.hibernate.association.one2one下新建一个Demo.java文件。
/*
* Hibernate - 关联(Association)映射(一对多)
* 创建日期 2005-4-27
* @author javamxj(分享java快乐)
* @link Blog: htpp://blog.csdn.net/javamxj/
* htpp://javamxj.mblogger.cn
*/
package javamxj.hibernate.association.one2many;
import net.sf.hibernate.*;
import net.sf.hibernate.cfg.*;
public class Demo {
public static void main(String[] args) throws HibernateException {
User user1 = new User();
user1.setName("张三");
User user2 = new User();
user2.setName("李四");
User user3 = new User();
user3.setName("王二");
Room room1 = new Room();
room1.setAddress("科研007");
room1.getUsers().add(user1);
room1.getUsers().add(user2);
Room room2 = new Room();
room2.setAddress("销售001");
room2.getUsers().add(user3);
SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();
Session session = sessionFactory.openSession();
Transaction tx = session.beginTransaction();
session.save(room1);
session.save(room2);
tx.commit();
session.close();
sessionFactory.close();
}
}
· 运行这个类,数据表中生成如下数据:
· 同时,控制台输出如下:
· 这里关联方向是单向,并且关联关系由Room对象维持的。它首先存储的是Room对象,然后存储Room对应的多个User,这时User表上的关联字段Room_ID是Null,最后Room对象将自己的ID值赋予到User表上的Room_ID,完成每个User更新(update)对Room自己的关联。
Hibernate执行这些操作一共用了8条语句,如果使关联关系由User对象维持的,那么后面的3条updata语句是可以不用的,下篇文章会谈到这一点的。
· 最后的项目结构如下: