本文主要是介绍Hibernate4.0 注解 @ManyToMany @JoinTable @OrderBy,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
ManyToMany注释:表示此类是多对多关系的一边,
(mappedBy属性定义了此类为双向关系的维护端,注意:mappedBy 属性的值为此关系的另一端的属性名。)
总结:
@ManyToMany注释表示Role是多对多关系的一端。@JoinTable 描述了多对多关系的数据表关系。name 属性指定中间表名称,joinColumns 定义中间表与User表的外键关系 ,代码中,中间表s_role_menu 的role_ID 列是Role表的主键列对应的外键列,inverseJoinColumns 属性定义了中间表与另外一端(menu)的外键关系.
只有两个实体类都配置了joinColumns和inverseJoinColumns属性,并且位置互相调换,就可以使用双向维护。
比如你删除角色时,角色会删除角色与菜单表的关系,也会删除角色中与用户的关系表。
@OrderBy 排序的字段(查询出的数据是乱序的)
关系建立后 数据库中建表只需要两个字段值,关系表的主键,hibernate会自动映射,执行insert语句。
@ManyToMany(fetch= FetchType.LAZY)
@JoinTable(name= "s_role_menu", joinColumns = {@JoinColumn(name = "menu_id", nullable = false, updatable = false) },inverseJoinColumns = { @JoinColumn(name = "role_id", nullable =false, updatable = false) })
@OrderBy("id ASC")
public Set<Srole> getRoles() {
return roles;
}
@ManyToMany(fetch=FetchType.LAZY)
@JoinTable(name= "s_role_menu", joinColumns = { @JoinColumn(name ="role_id", nullable = false, updatable = false) }, inverseJoinColumns= { @JoinColumn(name = "menu_id", nullable = false, updatable =false) })
@OrderBy("id ASC")
public Set<Smenu> getMenus() {
return menus;
}
这篇关于Hibernate4.0 注解 @ManyToMany @JoinTable @OrderBy的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!