Hiberante学习之复合主键的映射

王朝other·作者佚名  2007-07-17
窄屏简体版  字體: |||超大  

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

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航