Mybatis系列番外篇之多参数
引言
使用过Mybatis的小伙伴们都知道,在映射文件中只能使用parameterType属性指定一个传入参数,可是在实际的项目中,往往需要用到多个传入参数,那么应该如何实现呢?本文就以Mybatis接口式编程方式来分享一下我的实现方式。
分层设计
在实际的工作项目中,需要使用用户和角色的概念对系统权限进行管理,那么就引出了为用户分配角色的问题。
Service层
通常我们会在Service层定义一个方法用来为用户添加角色。这个方法需要传入两个参数,一个是用户id,另一个是角色id列表,方法签名如下。
public void grantRoles(int userId, List<Integer> roleIds) throws NotFoundException;
Dao层
但是在Dao层却不可以使用这样的方法签名,因为Mybatis的映射文件中,只能使用parameterType指定一个传入参数,所以,方法签名就变成这个样子了。
public void grantRoles(Map<String, Object> parameter);
这里使用了Map类型对Service层传入的两个参数进行了包装,将其转为一个参数。
当然,在编写映射文件时,也可以不使用parameterType属性来指定传入参数类型,这样就可以使用类似#{0},#{1}...方式来顺序获取传入的参数。
只是这种方式不适用于此场景中,因为在为用户分配角色时,角色的数量是不确定的,这样就没法确定传入参数的数量。所以使用Map类型对传入参数进行封装。
Mybatis映射文件
<insert id="grantRoles" parameterType="java.util.Map"> INSERT IGNORE sec_user_role(user_id, role_id) VALUES <foreach collection="roleIds" item="item" index="index" separator=","> (#{userId}, #{item}) </foreach> </insert>
在配置文件中出现的userId和roleIds是则是Map参数中的两个Key,#{userId}则是取出对应的value,由于roleIds对应的值是一个List类型,所以,这里使用了foreach标签遍历列表中的所有值。
Service层实现代码
@Override public void grantRoles(int userId, List<Integer> roleIds) throws NotFoundException { User user = this.getById(userId); if (null != user) { Map<String, Object> parameter = new HashMap<String, Object>(); parameter.put("userId", userId); parameter.put("roleIds", roleIds); dao.grantRoles(parameter); } else { String msg = "数据库中查找不到Id为[" + userId + "]的用户!"; logger.error(msg); throw new NotFoundException(msg); } }
相关推荐
Mybatis系列学习源码 详细学习系列请参考http://www.cnblogs.com/daviddai/p/3485574.html
mybatis之多对多
多个参数传递 传入单个实体(JavaBean/Map) 传入多个实体 传入集合 使用场景 在实际开发过程中,我们往往需要编写复杂的SQL语句,拼接稍有不注意就会导致错误,Mybatis给开发者提供了动态SQL,大大降低了拼接SQL导致的...
MyBatis传入多个参数
非常好用的,就是你们所要的 Mybatis日志参数快速替换占位符 sql参数替换工具html
Mybatis3系列课程8-带参数查询
Mybatis系列教程Mybatis插件共8页.pdf.zip
Mybatis 入门到理解篇,Mybatis 入门到精通,基础知识
深入浅出mybatis系列 适合自学、初学者使用
Mybatis Log(自动填充sql参数打印到控制台)
Mybatis多参数查询与列表查询不同方式实现,效果看博文 http://blog.csdn.net/evankaka/article/details/45671473
今天小编就为大家分享一篇关于mybatis利用association或collection传递多参数子查询,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
方法多参数@Param。
下面小编就为大家带来一篇MyBatis拦截器:给参数对象属性赋值的实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
Java开发系列MyBatis使用以及实现Java开发系列MyBatis使用以及实现Java开发系列MyBatis使用以及实现Java开发系列MyBatis使用以及实现Java开发系列MyBatis使用以及实现Java开发系列MyBatis使用以及实现Java开发系列...
mybatis 多层级collection嵌套
Mybatis系列课程-Association
Mybatis系列教程Mybatis缓存共17页.pdf.zip
Mybatis系列五.avi
Mybatis系列二.avi