批量查询的全过程(学习笔记)

本文详细介绍了如何在SpringMVC框架中实现用户及其角色的管理功能,包括使用UserService和RoleService查询用户列表及角色,通过UserMapper层从数据库获取用户信息,并利用MyBatis动态SQL实现数据查询。

具体步骤如下:
1 controller层(查询开始的接口)
① 调用UserService查询用户列表
② 调用RoleService查询当前用户所拥有的角色list

@RequestMapping("listUser")
	public String list(Model model) {
		//查询用户
		List<User> user = userService.list();
		model.addAttribute("user", user);
		//用户角色对应map
		Map<User, List<Role>> user_roles = new HashMap<>();
		for (User user : user) {
			//获得当前用户所拥有的角色list
			List<Role> roles = roleService.listRoles(user);
			user_roles.put(user, roles);
		}
		model.addAttribute("user_roles", user_roles);
		return "listUser";
	}

2 调用UserService查询用户,返回一个用户list,具体实现在它的实现层中,代码如下:
① 调用UserMapper层从数据库进行查询

@Override
	public List<User> list() {
	//相当于用户的一个工具类,设置查询结果list的排序规则
		UserExample example = new UserExample();
		//当前查询到的用户按降序排序
		example.setOrderByClause("id desc");
		return userMapper.selectByExample(example);

	}

3 UserMapper层的方法如下:返回一个用户list

List<User> selectByExample(UserExample example);

4 UserMapper.xml具体如下:

<select id="selectByExample" parameterType="com.how2java.pojo.UserExample" resultMap="BaseResultMap">
    select
    <if test="distinct">
      distinct
    </if>
    'false' as QUERYID,
    <include refid="Base_Column_List" />
    from user
    <if test="_parameter != null">
      <include refid="Example_Where_Clause" />
    </if>
    <if test="orderByClause != null">
      order by ${orderByClause}
    </if>
  </select>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值