hibernate笔记--单向多对一映射方法
2016-03-02 20:27
453 查看
假设我们要建两张表,学生信息表(student)和年级信息表(grade),关系是这样的:
我们可以看出学生表和=年级表是多对一的关系,多个学生会隶属于一个班级,这种关系在hibernate中成为单边的多对一的关系,需要这样配置:
新建实体类Grade:
新建实体类Student:
当前包下新建Grade类的映射文件Grade.hbm.xml:
当前包下新建Student类的映射文件student.hbm.xml:
新建一个测试类,测试生成数据库表以及向数据库表中添加数据:
我们可以看出学生表和=年级表是多对一的关系,多个学生会隶属于一个班级,这种关系在hibernate中成为单边的多对一的关系,需要这样配置:
新建实体类Grade:
public class Grade { private int id; private String name; private String teacher; //get/set方法省略 }
新建实体类Student:
public class Student { private int id; private String name; private String sex; private Grade grade; //get/set方法省略 }
当前包下新建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> </class> </hibernate-mapping>
当前包下新建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> <!-- 该标签配置多对一的关系 name:指定实体类中对应的属性 column:指定外键列名 class:指定属性所属的类 not-found:默认为exception,表示Gradebu不存在,则抛出异常,可以修改为ignore,忽略异常 cascade:制定级联保存选项, --> <many-to-one name="grade" class="Grade" column="gradeId" ></many-to-one> </class> </hibernate-mapping>
新建一个测试类,测试生成数据库表以及向数据库表中添加数据:
@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(1, "初三一班", "王永"); session.save(g); Student s=new Student("张三", "男", g); session.save(s); tx.commit(); session.close(); }
相关文章推荐
- 最佳实践: 勿在 Servlet 中实现 SingleThreadModel
- Win32多线程编程学习心得
- POJ2528Mayor's posters(离散化 + 线段树)
- overflow:hidden与margin:0 auto之间的冲突
- js循环使用
- Linux搭建
- CNN中感受野的计算
- 基本sql语句
- ubutnu 14.04LTS 安装opencv2.4
- string类型的查找
- jQuery--加一行减一行
- LeetCode 173. Binary Search Tree Iterator
- js限制input只能输入有效的数字,有且只有一个小数点,第一个不能为小数点-备
- javascript、js计算两个日期之间的天数
- Overlaying the Action Bar --1.1.4
- 深入探讨 Java 类加载器【转】
- guava学习笔记-集合
- React Native 的那些坑
- [ZOJ1654]Place the Robots 做题笔记
- 627 A codeforces