一对多映射
在上一节中,我们使用了4种方法实现一对一映射,这一节,一对多映射只有两种配置方式,都是使用collection标签进行的
collection集合的嵌套结果查询
和association类似,集合的嵌套结果查询就是通过一次SQL查询将所有的结果查询出来,然后通过配置的结果映射,将数据映射到不同的对象中去,在一对多的关系中,主表的一条数据会对应关联表中的多条数据,因此一般查询结果会有多个,按照一对多的数量结果存储数据的时候,最终的结果数会小于等于查询的总记录数
在RBAC权限系统中,一个用户拥有多个角色,每个角色又是多个权限的集合,所以要渐进式地去实现一个SQL,查询出所有用户和用户拥有的角色,以及角色所包含的所有权限信息的两层嵌套结果
我们先来实现一层嵌套结果,修改SysUser类如下:
/**
* 用户表
* @author Administrator
*
*/
public class SysUser {
//原有属性
/**
* 用户的角色集合
* @return
*/
private List<SysRole> roleList;
public List<SysRole> getRoleList() {
return roleList;
}
public void setRoleList(List<SysRole> roleList) {
this.roleList = roleList;
}
在SysUser类中增加roleList属性用于存储用户对应的多个角色