Hiberante学习之复合主键的映射

当数据库中两个表(表A和表B)存在多对多的关系时,一般会再设一个中间表(表C),和表A、B形成多对一的关系;而这个中间表C由多个主键组成复合主键,这些主键都是表A、B的外键。

复合主键的映射和一般字段的映射有点不同,一般是以下两种方法:

方法一:

映射代码
<class name="simple.test.User" table="user">
   <composite-id>
         <key-property name="name" column="name" type="java.lang.String"/>
         <key-property name="age" column="age" type="java.lang.Integer"/>
   </composite-id>
   .............
</class>

然后创建一个User对象,并用session的save()保存它
User user = new User();
user.setName("test");
user.setAge("20");
session.save(user):

方法二:定义单独的主键类

映射代码
<class name="simple.test.User"  table="user">
    <composite-id name="sysUser" class="simple.test.UserPK">
         <key-property name="name" column="name" type="java.lang.String"/>
         <key-property name="age" column="age" type="java.lang.Integer"/>
    </composite-id>
    ............
</class>

创建一个User类,一个UserPk类,用session的save()保存User类的对象

UserPK.java的部分代码:
public class UserPK implements Serializable
{
   private String name;
   private int age;

   public UserPK(String name,int age)
  {
      this.name = name;
      this.age = age;
  }
 
  public setName(String name)....
  public getName().....
  public setAge(int age)....
  public getAge()........
 ..................
}

User.java的部分代码:
public class User implements Serializable
{
    private UserPK userPK;

    public User(){}
    public setUserPK(UserPK userPK)
    {
       this.userPK = userPK;
    }
   
    Public getUserPK()
    {
         return userPK;
    }
    ....................
}


UserPk userPk = new UserPk("test","20")
Use user = new User();
user.setUserPk(userPk);
session.save(user);

 注意:
 无论是User类还是独立主键类都要
 1。实现Serializable接口
 2。覆写equals()和hashCode()方法
  
 
另外可以利用一些自动化的方法生成,详情请看 用hibernate-extensions自动生成POJO对象 

你可能感兴趣的:(java,C++,c,Hibernate,C#)