在上一篇文章---Hibernate框架学习(1)中学习的是单表操作。
在这篇文章中将介绍Hibernate一对多映射。
如何实现一对多
1.在数据库中,可以通过添加主外键的关联,表现一对多的关系
2.在java中 , 通过在一方持有多方的集合实现,即在“一”的一端中使用<set>元素表示持有“多”的一端的对象
Myeclipse创建hibernate实例步骤:
在上一篇文章中使用eclipse+SQL server实现单表操作,在此文章中使用Myeclipse+SQL server实现Hibernate一对多映射
1.安装Myeclipse和MS SQL server
2.创建一个Web项目
3.在菜单栏中Windows一栏中,选择show view中的DB browser,如果没找到就在other中寻找

4.在DB browser栏中右击,选择new,配置好数据库相关信息,并添加好相应驱动

Myeclipse配置hibernate步骤
方法1.java project -> -> myeclipse -> add hibernate capabilities ->....

选择配置相关信息

得到的hibernate.cfg.xml文件,可手动添加其余相关配置

方法2.手动添加hibernate的jar包,新建lib目录,复制jar包入内;再进行Hibernate.cfg.xml配置,与在eclipse中添加类似,在Myeclipse中不需要向eclipse中再配置软件环境
创建HibernateUtil工具类
在进行操作hibernate的时候,我们需要去获取会话,建一个工具类,用来进行会话的获取和关闭
通过静态代码块初始化会话工厂

获取会话工厂SessionFactory

获取Session

关闭Session

在SQL server数据库中建立表
在数据库中,可以通过添加主外键的关联,表现一对多的关系
T/SQL代码如下

students表中与grade表中的班级号通过使用外键关联
创建持久化和映射文件并配置单向一对多关系
a.持久化类(Java beans格式)
1.创建学生持久化类

2.创建班级持久化类(在一方定义一个多方集合)

b.配置映射文件
方法1:使用自动生成方法,在DB Browser栏中选择要建立的表,右击选择Hibernate Reverse Engineering


完成配置,但这种方法会改动原持久化类中内容,产生一些问题,不建议使用
方法2:手动编写,复制一份.hbn.xml文件,更改名字,删除多余内容,手动输入配置.
students.hbn.xml配置

grade.hbn.xml配置

红框部分为配置一对多的集合属性
手动添加时注意要在hibernate.cgf.xml文件中添加映射

对学生信息进行增删改查(CRUD)
hibernate 大体的执行流程:
1.首先创建一个配置对象叫configuration用于读取配置文档hibernate.cfg.xml
Configuration config=new Configuration().configure();
2.目的是用于创建sessionFactory对象
SessionFactory sessionFactory=config.buildSessionFactory();
创建sessionFactory对象时就会读取相应的关系映射文件Students.hbm.xml
3.获得sessionfactory对象后就可以创建session对象
Session session=sessionFactory.openSession();
类似于jdbc中的Connection对象,获得一个session对象就相当于获取到一个数据库链接对象,我们就可以执行session的功能save、delete、update、get等功能
4.在执行session的某个方法是必须要开启一个事务
Transaction transaction=session.beginTransaction();
因为方法需要封装在事务当中,在执行完方法
session.save(s)/delete(s) ;
后要提交事务
transaction.commit();
然后关闭session
session.close();
单项一对多关联关系(班级-->学生)
建立关联关系之后,可以方便从一个对象导航到另一个对象
注意关联方向
增加学生信息程序

查看学生信息

更改学生信息

删除学生信息

网友评论