上一篇讲的是单向多对一的表关系,与单向一对多的关系正好相反,如下图所示关系:
,可以看出年级表和学生表是一对多的关系,一条年级信息对应多条学生信息,在hibernate中成为单向的一对多的映射关系,应该这些操作:
新建Student实体类:
public class Student {
private int id;
private String name;
private String sex;
//get/set方法省略
}
新建Grade实体类:
public class Grade {
private int id;
private String name;
private String teacher;
private Set<Student> students=new HashSet<Student>(0);
//get/set方法省略
}
注意:由于一条年级信息会包含多条学生信息,这里使用了一个set集合保存学生信息,也可以使用list,或map,这里主要考虑set不能保存重复数据.
在当前包下新建Student的映射文件Student.hbm.xml:
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="com.wang.pojo">
<class name="Student" >
<id name="id">
<generator class="native"></generator>
</id>
<property name="name"></property>
<property name="sex"></property>
</class>
</hibernate-mapping>
当前包下新建Grade的映射文件Grade.hbm.xml:
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="com.wang.pojo">
<class name="Grade" >
<id name="id">
<generator class="native"></generator>
</id>
<property name="name"></property>
<property name="teacher"></property>
<!-- set是一种集合属性,用来配置set等,如果使用的是list,则使用list标签,这里是Grade的集合属性 name是属性名称 -->
<set name="students">
<!-- key表示外键 column表示外键列名 -->
<key column="grade_id" not-null="true"></key>
<one-to-many class="Student"/>
</set>
</class>
</hibernate-mapping>
将两个映射文件添加到hibernate.cfg.xml中,新建测试类,测试1:表的生成2:保存数据3:读取数据:
@Test
public void testCreateDB() {
Configuration cfg = new Configuration().configure();
SchemaExport se = new SchemaExport(cfg);
// 第一个参数是否生成ddl脚本 第二个参数是否执行到数据库
se.create(true, true);
}
@Test
public void testSave() {
Session session = HibernateUtil.getSession();
Transaction tx = session.beginTransaction();
// Score s=new Score(2,12,97);
// session.save(s);
Grade g=new Grade();
g.setName("终极一班");
g.setTeacher("张召忠");
Student s1=new Student(12,"王二小","男");
Student s2=new Student(13,"郭靖","男");
Student s3=new Student(14,"黄蓉","女");
g.getStudents().add(s1);
g.getStudents().add(s2);
g.getStudents().add(s3);
session.save(g);
session.save(s1);
session.save(s2);
session.save(s3);
tx.commit();
session.close();
}
@Test
public void testGet() {
Session session = HibernateUtil.getSession();
Transaction tx = session.beginTransaction();
Grade g=(Grade)session.get(Grade.class, 1);
System.out.println("id="+g.getId()+"name="+g.getName()+"teacher="+g.getTeacher());
Iterator<Student> it = g.getStudents().iterator();
while(it.hasNext()){
Student s=it.next();
System.out.println(s);
}
tx.commit();
session.close();
}
注意:添加数据时,如果在Grade的外键列grade_id中设置了not-null="true",则添加数据的时候需要先添加grade,再添加Studnet,因为如果先添加student信息的时候,外键值会找不到.