hibernate笔记--单向一对多映射方法

  上一篇讲的是单向多对一的表关系,与单向一对多的关系正好相反,如下图所示关系:

,可以看出年级表和学生表是一对多的关系,一条年级信息对应多条学生信息,在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信息的时候,外键值会找不到.

 

posted @ 2016-03-03 10:29  冬至饮雪  阅读(330)  评论(0编辑  收藏  举报