1.联合主键的映射规则

1) 类中的每个主键属性都对应到数据表中的每个主键列。

Hibernate要求具有联合主键的实体类实现Serializable接口,并且重写hashCode与equals方法,重写这两个方法的原因在于Hibernate要根据数据库的联合主键来判断某两行记录是否是一样的,如果一样那么就认为是同一个对象,如果不一样,那么就认为是不同的对象。这反映到程序领域中就是根据hashCode与equals方法来判断某两个对象是否能够放到诸如Set这样的集合当中。联合主键的实体类实现Serializable接口的原因在于使用get或load方法的时候需要先构建出来该实体的对象,并且将查询依据(联合主键)设置进去,然后作为get或load方法的第二个参数传进去即可。

2) 将主键所对应属性提取出一个类(称之为主键类),并且主键类需要实现Serializable接口,重写equals方法与hashCode方法,原因与上面一样。

以Student类为例,实现上述两种映射联合主键的配置:

2.Student中的两个属性作为联合主键属性

Student类:

  1. public class Student implements Serializable {//必须要实现Serializable接口
  2. private String cardID;//cardID和name映射为联合主键
  3. private String name;
  4. private int age;
  5. //get、set、hashCode、equals方法省略
  6. }

注:可使用MyEclipse中的Sourse-->Gennerate hashCode and equals来使用MyEclipse快速生成hashCode和equals方法

Student.hbm.xml配置:

  1. <class name="bean.Student" table="student">
  2. <composite-id><!--联合主键,student表中的主键为(student_name,card_id)-->
  3. <key-property name="name" column="student_name" type="string"></key-property><!--name及cardID为Student类中的属性-->
  4. <key-property name="cardID" column="card_id" type="string"></key-property>
  5. </composite-id>
  6. <property name="age" column="student_age" type="int"></property>
  7. </class>

保存对象:

  1. tx=session.beginTransaction();
  2. Student s1=new Student();
  3. s1.setName("lisi");
  4. s1.setAge(22);
  5. s1.setCardID("711");
  6. System.out.println(s1);
  7. session.save(s1);
  8. tx.commit();

注意:主键为(card_id,student_id)若连续执行上述的保存语句两次,当然会抛异常,应为主键重复:   
           org.hibernate.exception.ConstraintViolationException: Could not execute JDBC batch update
3.将Student类中的两个主键属性提取为一个新的类PrimaryKey,即主键类

主键类PrimaryKey:

  1. public class PrimaryKey implements Serializable{
  2. private String cardID;
  3. private String name;
  4. //get、set、hashCode、equals方法省略
  5. }

Student类中含有PrimaryKey类型的属性及对应set、get方法:

  1. public class Student  {
  2. private int age;
  3. private PrimaryKey primaryKey;
  4. //set、get方法省略
  5. }

Student.hbm.xml文件中的配置:

  1. <class name="bean.Student" table="student">
  2. <composite-id name="primaryKey" class="bean.PrimaryKey"><!--PrimaryKey为我们自定义的主键类-->
  3. <key-property name="name" column="student_name" type="string"></key-property><!--name及cardID为PrimaryKey类中的属性-->
  4. <key-property name="cardID" column="card_id" type="string"></key-property>
  5. </composite-id>
  6. <property name="age" column="student_age" type="int"></property>
  7. </class>

保存对象:

  1. tx=session.beginTransaction();
  2. Student s1=new Student();
  3. s1.setAge(23);
  4. PrimaryKey p=new PrimaryKey();
  5. p.setCardID("102");
  6. p.setName("zhangsan");
  7. s1.setPrimaryKey(p);
  8. session.save(s1);
  9. tx.commit();

同样,对于上述代码的重复执行也会导致主键重复抛出异常。

查询:

  1. PrimaryKey p=new PrimaryKey();
  2. p.setCardID("711");
  3. p.setName("lisi");
  4. Student s=(Student)session.get(Student.class,p);//所以PrimaryKey要实现Serializable接口
  5. System.out.println(s.getAge());

4.对于以上两种映射联合主键的方式,反映到数据库中的表的结构是相同的,student表的内容为:

转载请注明出处:http://blog.csdn.net/jialinqiang/article/details/8704538

Hibernate联合主键映射的更多相关文章

  1. Hibernate 中 联合主键映射 组合关系映射 大对象映射(或者说文本大对象,二进制数据大对象)

    Clob:文本大对象,最长4G Blob:二进制数据大对象,最长4G util: public class HibUtil { private static SessionFactory sessio ...

  2. hibernate 联合主键生成机制(组合主键XML配置方式)

    hibernate 联合主键生成机制(组合主键XML配置方式)   如果数据库中用多个字段而不仅仅是一个字段作为主键,也就是联合主键,这个时候就可以使用hibernate提供的联合主键生成策略. 具体 ...

  3. hibernate 联合主键 composite-id

    如果表使用联合主键(一个表有两个以上的主键),你可以映射类的多个属性为标识符属性.如:<composite-id>元素接受<key-property> 属性映射(单表映射)和& ...

  4. 这是一个hibernate 联合主键的例子

    package com.bird.entity; import java.io.Serializable; import javax.persistence.Entity; import javax. ...

  5. Hibernate一对一主键映射

    Hibernate一对一主键映射                        ------------------------------                            -- ...

  6. Java进阶知识05 Hibernate联合主键之Annotation(注解)和XML实现方式

    1.Hibernate联合主键(Annotation实现) 1.1.单列主键 1.1.1.为什么要有主键? //唯一确定一条记录    1.1.2.一个表能否有多个主键? //不能    1.1.3. ...

  7. hibernate 注解 联合主键映射

    联合主键用Hibernate注解映射方式主要有三种: 第一.将联合主键的字段单独放在一个类中,该类需要实现java.io.Serializable接口并重写equals和hascode,再将 该类注解 ...

  8. hibernate 联合主键

      xml方式处理联合主键:   以有两个主键:id和name的student表为例. 先创建个主键类:   package com.bjsxt.hibernate; //黑色为必写项 public ...

  9. Hibernate 组合主键映射

    在开发过程中创建数据库表时,有时候会发现单纯的创建一个主键是不可行的,有时候就需要多个字段联合保持唯一,本文讲述如何创建组合主键的映射. 例如:记录一个班的考试成绩.学生跟科目是多对多的关系,只有一个 ...

随机推荐

  1. SQL Server 基础:拾遗

    1.一条完整的sql语句: select top | distinct 字段, 表达式, 函数, ... from 表表达式 where 筛选条件 group by 分组条件 having 筛选条件 ...

  2. C# 平时碰见的问题【5】

    vs按F5启动调试,项目不会编译的解决办法 工具 -> 选项 -> 项目和解决方案 -> 运行时, 当项目过期(下拉框) -> 不要选[从不生成] 附英文版的:

  3. SHOW SLAVE STATUS几个常见参数

    --显示当前读取的Master节点二进制日志文件和文件位置,对应线程I/O thread Master_Log_File: mysql-bin.000011 Read_Master_Log_Pos: ...

  4. iOS开发常用的宏

    #define SCREEN_WIDTH ([UIScreen mainScreen].bounds.size.width)#define SCREEN_HEIGHT ([UIScreen mainS ...

  5. mamp pro

    MAMP PRO Settings and Files /Library/Application Support/appsolute/MAMP PRO ~/Library/Application Su ...

  6. StyleCop学习笔记——初识StyleCop

    一.定义 StyleCop是微软的一个开源的静态代码分析工具,检查c#代码一致性和编码风格. 二.支持的环境. JetBrains R# 5.1.3 ( 5.1.3000.12) JetBrains ...

  7. mybatis数据库基本配置包括数据源事物类型等

    <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configuration PUBLIC ...

  8. Linux获取线程tid线程名

    Linux获取线程tid线程名 1 2 3 4 5 6 //thread name char cThreadName[32] = {0}; prctl(PR_GET_NAME, (unsigned l ...

  9. 微价值:专访《甜心爱消除》的个人开发者Lee,日入千元

    [导语] 我们希望能够对一些个人开发者进行专访,这样大家更能显得接地气,看看人家做什么,怎么坚持.<甜心爱消除>作者Lee是三群的兄弟,也关注微价值.微价 值的文章还是可以的,得到一些业内 ...

  10. Entity Framework 学习第一天 续

    改写第一天的增删改查方法,观察增删改查的本质 using System; using System.Collections.Generic; using System.Data.Entity.Infr ...