`
禹爸爸
  • 浏览: 86421 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
社区版块
存档分类
最新评论

Mybatis系列番外篇之多参数

阅读更多

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>

在配置文件中出现的userIdroleIds是则是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);
		}
	}

 

 

 

 

0
0
分享到:
评论

相关推荐

    Mybatis系列学习源码

    本资源是"Mybatis系列学习源码",适合初学者和有一定经验的开发者深入理解Mybatis的工作原理和实践应用。下面将详细探讨Mybatis的核心概念和关键功能。 1. **SqlSession与Executor** - **SqlSession**:它是...

    mybatis 动态sql及参数传递

    多个参数传递 传入单个实体(JavaBean/Map) 传入多个实体 传入集合 使用场景 在实际开发过程中,我们往往需要编写复杂的SQL语句,拼接稍有不注意就会导致错误,Mybatis给开发者提供了动态SQL,大大降低了拼接SQL导致的...

    Mybatis系列教程Mybatis插件共8页.pdf.z

    【标题】"Mybatis系列教程Mybatis插件共8页.pdf.z" 提供的信息表明,这是一个关于Mybatis框架的教程,特别关注Mybatis插件的使用。Mybatis是一款流行的Java持久层框架,它允许开发者直接编写SQL语句,提供灵活的数据...

    Mybatis 入门到理解篇

    Mybatis是一种支持定制化SQL、存储过程以及高级映射的持久层框架,它避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。Mybatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJOs(Plain Old ...

    mybatis 日志 sql参数替换工具

    非常好用的,就是你们所要的 Mybatis日志参数快速替换占位符 sql参数替换工具html

    Mybatis Log(自动填充sql参数打印到控制台)

    Mybatis 提供了一种日志机制,能够自动填充SQL参数并打印到控制台,这对于排查问题和理解查询逻辑非常有帮助。 首先,Mybatis的日志实现依赖于日志库,如Log4j、Logback或Java内置的java.util.logging。为了开启SQL...

    Mybatis3系列课程8-带参数查询

    在本课程中,"Mybatis3系列课程8-带参数查询"主要讲解了如何在Mybatis框架中进行带参数的数据库查询操作。Mybatis作为一款强大的持久层框架,极大地简化了Java开发中的数据库操作,而参数查询是其核心功能之一。下面...

    myBatis系列之七:事务管理

    本篇文章将深入探讨MyBatis系列中的第七部分——事务管理,这对于任何使用MyBatis进行数据操作的项目而言都是至关重要的。 事务管理是数据库操作的核心组成部分,它确保了数据的一致性和完整性。在MyBatis中,事务...

    MyBatis拦截器:给参数对象属性赋值的实例

    MyBatis拦截器是MyBatis框架中的一种插件机制,允许用户自定义代码来扩展MyBatis的功能。在这个特定的实例中,我们讨论的是一个用于给参数对象属性赋值的拦截器。这个拦截器的主要目标是在执行增删改操作时,自动为...

    mybatis利用association或collection传递多参数子查询

    "MyBatis多参数子查询使用association或collection" MyBatis是一款流行的Java持久层框架,提供了多种方式来实现复杂的数据库查询操作。其中,使用association或collection来传递多参数子查询是一种常用的方法。本文...

    Mybatis系列教程Mybatis注解开发共9页.pdf

    【标题】"Mybatis系列教程Mybatis注解开发共9页.pdf" 提供的是一个关于Mybatis框架注解开发的教程,重点在于讲解如何在Mybatis中使用注解进行数据库操作。Mybatis是一个轻量级的Java持久层框架,它允许开发者通过...

    Java开发系列MyBatis使用以及实现

    Java开发系列MyBatis使用以及实现Java开发系列MyBatis使用以及实现Java开发系列MyBatis使用以及实现Java开发系列MyBatis使用以及实现Java开发系列MyBatis使用以及实现Java开发系列MyBatis使用以及实现Java开发系列...

    MyBatis系列操作资源

    除了基本的一对一查询,MyBatis还支持一对多、多对一和多对多的复杂关联查询,同样通过resultMap和SQL查询语句来实现。在实践中,这些关联查询能帮助开发者构建更复杂的数据模型和业务逻辑。 此外,MyBatis还有其他...

    Mybatis系列教程Mybatis源码剖析共15页.pd

    【标题】"Mybatis系列教程Mybatis源码剖析共15页.pdf" 是一份详细的Mybatis框架源码解析教程,涵盖了Mybatis的核心概念和技术细节。这份教程深入浅出地介绍了Mybatis如何工作,以及其背后的代码实现,对于理解...

    Mybatis系列教程Mybatis复杂映射开发共6页.p

    【标题】"Mybatis系列教程Mybatis复杂映射开发共6页" 提供了一个关键信息,即本教程专注于Mybatis的复杂映射开发,这通常指的是在Mybatis框架中处理多对一、一对多、多对多等复杂数据关系的能力。Mybatis作为一个...

    Mybatis注解手写源码篇

    在本项目中,我们将探讨如何手写模拟Mybatis的注解实现,深入了解其参数解析、SQL执行以及结果处理的底层原理。 首先,我们要理解Mybatis注解的基本用法。Mybatis通过注解可以在Mapper接口的方法上直接声明SQL语句...

    mybatis系列一:开发环境搭建

    在本篇中,我们将深入探讨"Mybatis系列一:开发环境搭建"的相关知识,这将包括如何设置一个基于Maven的Mybatis开发环境,以及如何理解并使用Mybatis的核心概念。首先,我们需要明白Mybatis是一个优秀的持久层框架,...

    Mybatis系列教程Mybatis基本应用共9页.pdf

    【标题】:Mybatis系列教程Mybatis基本应用共9页.pdf 【描述】:这份教程是关于Mybatis基本应用的详细讲解,包含了9页丰富的内容,旨在帮助学习者深入理解和掌握Mybatis这一强大的持久层框架。 【标签】:Mybatis...

    Mybatis系列教程Mybatis架构原理共4页.pdf

    【标题】:Mybatis系列教程Mybatis架构原理共4页.pdf 【描述】:这个压缩文件包含了一份关于Mybatis架构原理的系列教程,总计四页的内容。Mybatis是一款优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。...

    Mybatis系列五.avi

    Mybatis系列五.avi

Global site tag (gtag.js) - Google Analytics