zoukankan      html  css  js  c++  java
  • Hibernate联合主键映射

    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.   
    3.     private String cardID;//cardID和name映射为联合主键  
    4.     private String name;  
    5.     private int age;  
    6.         //get、set、hashCode、equals方法省略  
    7. }  

    注:可使用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.   
    3. Student s1=new Student();  
    4. s1.setName("lisi");  
    5. s1.setAge(22);  
    6. s1.setCardID("711");  
    7. System.out.println(s1);  
    8. session.save(s1);  
    9. 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.   
    3.     private String cardID;  
    4.     private String name;  
    5.     //get、set、hashCode、equals方法省略  
    6. }  

    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.   
    3.  Student s1=new Student();  
    4.  s1.setAge(23);  
    5.  PrimaryKey p=new PrimaryKey();  
    6.  p.setCardID("102");  
    7.  p.setName("zhangsan");  
    8.  s1.setPrimaryKey(p);  
    9.  session.save(s1);  
    10.  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

  • 相关阅读:
    视频解析小技巧
    linux系统路由设置
    tracert路由跟踪命令
    php+nginx
    docker快速拉取镜像
    linux命令
    添加docker命令
    linux模糊查询文件名
    查看日志
    模板函数与模板类
  • 原文地址:https://www.cnblogs.com/qlong8807/p/4156057.html
Copyright © 2011-2022 走看看