Hiberante学习之复合主键的映射

本文介绍了当数据库中两个表存在多对多关系时,如何通过设置中间表及使用复合主键来解决这一问题。提供了两种复合主键的映射方法,一种是在类中直接映射复合主键属性,另一种是定义单独的主键类进行映射。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

当数据库中两个表(表A和表B)存在多对多的关系时,一般会再设一个 中间表(表C),和表A、B形成多对一的关系;而这个中间表C由多个主键组成复合主键,这些主键都是表A、B的外键。 复合主键的映射和一般字段的映射由一定的不同,一般是一下两种方法:

 

当数据库中两个表(表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对象


 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值