MyBatis--高级查询(二)

一对多映射

在上一节中,我们使用了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属性用于存储用户对应的多个角色

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

荒--

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值