hibernate多对多映射

hibernate多对多映射

<script></script>标签:

hibernate映射

分类: JAVA技术
<!-- 正文开始 -->

一.hibernate多对多映射(单项),自动产生第三张表

User-- Role

user(id,name)    role(id,name)

User类:

private int  id;   private String name;  private  Set roles;

 
Role类:

private int id;    private String name;

 
User.hbm.xml中:

<set name=”roles” table=”t_user_role”>

       <key column=”userid” />

       <many-to-many class=”com.Role” column=”roleid” />

</set>

 

这样,hibernate会自动产生中间表t_user_role(userid,roleid) 并且是复合主键,userid为t_user的外键,roleid为t_role的外键

 
二.hibernate多对多的存储

 
Role r1 = new Role();

r1.setName(“数据录入人员”);

 
Role r2 = new Role();

r2.setName(“商务主管”);

 
Role r3 = new Role();

r3.setName(“大区经理”);

 
User u1 = new User();

u1.setName(“10”);

Set u1Roles = new HashSet();

u1Roles.add(r1);

u1Roles.add(r2);

u1.setRoles(u1Roles);

 
User u2 = new User();

u1.setName(“祖儿”);

Set u2Roles = new HashSet();

u2Roles.add(r2);

u2Roles.add(r3);

u2.setRoles(u2Roles);


User u3 = new User();

u3.setName(“杰伦”);

Set u3Roles = new HashSet();

u3Roles.add(r1);

u3Roles.add(r2);

u3Roles.add(r3);

u3.setRoles(u3Roles);

 
session.save(r1);

session.save(r2);

session.save(r3);

 
session.save(u1);

session.save(u2);

session.save(u3);

 
结束之后,在第三张表中也有数据

 
三.hibernate多对多的加载

 
User user = (User)session.load(User.class,1);

System.out.println(user.getName());

for(Iterator iter = user.getRoles().iterator();iter.hasNext();){

       Role role = (Role)iter.next();

       System.out.println(role.getName());

}

 每次加载都会发出sql语句

三.hibernate多对多的 双向映射

User -Role

user(id,name)    role(id,name)

User类:

private int  id;   private String name;  private Set roles;

 
Role类:

private int id;    private String name; private Set users;

 
User.hbm.xml中:

<set name=”roles” table=”t_user_role”>

       <key column=”userid” />

       <many-to-many class=”com.Role” column=”roleid” />

</set>

 
Role.hbm.xml中:

<set name=”roles” table=”t_user_role”>   //这里可以设置order-by=”userid”,根据userid排序

       <key column=”roleid” />

       <many-to-many class=”com.User” column=”userid” />

</set>

 
注意,上面中间表名字是一样的

这样,hibernate也会自动产生中间表t_user_role(userid,roleid) 并且是复合主键,userid为t_user的外键,roleid为t_role的外键

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值