zoukankan      html  css  js  c++  java
  • 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信息的时候,外键值会找不到.

  • 相关阅读:
    C++ 编码转换
    获取文件扩展名
    字符串分割(C++)(转载)
    Visual Leak Detector简明使用教程
    Win32 文件拖拽
    IMAP协议命令(详细)
    CreateDirectory 创建文件夹 CC++
    编程习惯总结
    GitHub上整理的一些工具,求补充
    jquery生成qrcode二维码
  • 原文地址:https://www.cnblogs.com/fingerboy/p/5237583.html
Copyright © 2011-2022 走看看