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