Hibernate Annotation 实现多对多关联

本文介绍了一种常见的User-Role关系映射方式,通过USERS、ROLES及USER_ROLE三张表来实现用户与角色之间的多对多关联,并详细解释了如何在Java环境下使用JPA注解来定义这种关系。

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

表结构是常见的User-Role关系,USERS表保存用户信息,ROLES表保存角色信息,USER_ROLE交叉表保存用户-角色对应关系.USERS表对应User类,ROLES表对应Role类。其中,User作为主控方。
在Role中,Set<User> users = new HashSet<User>(0);指向User,同样,User中的roles属性指向Role.
在User中:
[code]
@ManyToMany(cascade = { CascadeType.PERSIST, CascadeType.MERGE },
fetch = FetchType.LAZY)
@JoinTable(name="USER_ROLE", joinColumns={@JoinColumn(name="USER_ID")},
inverseJoinColumns={@JoinColumn(name="ROLE_ID")})
public Set<Role> getRoles() {
return this.roles;
}
[/code]
在Role中:
[code]
@ManyToMany(cascade = {CascadeType.PERSIST, CascadeType.MERGE },
fetch = FetchType.LAZY, mappedBy="roles")
public Set<User> getUsers() {
return this.users;
}
[/code]
注意mappedBy的用法,相当于HBM的inverse属性。
使用的时候需要注意建立双向关联
[code]
Role role = new Role();
User user = new User();
role.getUsers().add(user);
user.getRoles().add(role);
save(role);
save(user);
[/code]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值