当数据库中两个表(表A和表B)存在多对多的关系时,一般会再设一个 中间表(表C),和表A、B形成多对一的关系;而这个中间表C由多个主键组成复合主键,这些主键都是表A、B的外键。 复合主键的映射和一般字段的映射由一定的不同,一般是一下两种方法:
当数据库中两个表(表A和表B)存在多对多的关系时,一般会再设一个中间表(表C),和表A、B形成多对一的关系;而这个中间表C由多个主键组成复合主键,这些主键都是表A、B的外键。
复合主键的映射和一般字段的映射有点不同,一般是以下两种方法:
方法一:
映射代码
<key-property name="name" column="name" type="java.lang.String"/>
<key-property name="age" column="age" type="java.lang.Integer"/>
.............
然后创建一个User对象,并用session的save()保存它
User user = new User();
user.setName("test");
user.setAge("20");
session.save(user):
方法二:定义单独的主键类
映射代码
User" table="user">
UserPK">
<key-property name="name" column="name" type="java.lang.String"/>
<key-property name="age" column="age" type="java.lang.Integer"/>
............
创建一个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);
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10294527/viewspace-122060/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/10294527/viewspace-122060/
博客介绍数据库中两表存在多对多关系时,会设中间表形成多对一关系,中间表由多个主键组成复合主键。还阐述了复合主键映射与一般字段映射不同,给出两种映射方法,包括映射代码及创建对象保存的示例。
206

被折叠的 条评论
为什么被折叠?



