Mybatis参数(Parameters)传递方式

 更新时间:2023年12月04日 09:38:27   作者:路在何方い  
这篇文章主要介绍了Mybatis参数(Parameters)传递方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

1.单个普通类型(基本类型、包装类型、String)的参数

封装规则:Mybatis不会做特殊的处理

取值 #{随便写,建议与实际的参数名保持一致}

例如:

操作:public Employee getEmployeeById(Integer id );

取值:#{id}

	<!-- 关于select 的查询语句 resulType:查询结果对应的类型        id 当前sql语句的唯一标识       
	#{id}:获取传递的参数         resultType用于指定结果集的封装类型 
	parameter:确定传递参数的类型,也可以省略,mybatis会自动识别当前参数类型是什么
	-->
	<select id="getEmployeeById" resultType="employee"  parameterType="java.lang.Integer" 
	 databaseId="mysql">
		select id,last_name lastName,email,gender from tbl_employee where
		id=#{id}
	</select>

2.多个参数

封装规则:Mybatis会把多个参数封装成一个Map,封装时使用的key是:0 1 2 ....N-1/param1param2....paramN.

取值:#{0 1 2 ....N-1/param1param2....paramN}

例如:

操作:public Employee getEmpsByLastNameAndId(String lastName, Integer id );

取值:#{lastName}、#{id}错误

异常:Cause: org.apache.ibatis.binding.BindingException: Parameter 'lastName' not found. Available parameters are[0, 1, param1, param2]

取值:#{0}、#{1} 或者#{param1}、#{param2}正确

不方便:参数一旦多了,不知道参数具体在第几个位置

<!--${param1} and id=${param2} 参数一旦多了 不知道参数具体在第几个位置 -->
	<select id="getEmpsLastNameAndId" resultType="employee">
		select * from tbl_employee where last_name=#{param1} and id=#{param2}
	</select>

3.命名参数

使 用@Param()来指定多个参数封装Map时所使用的key

封装规则:Mybatis会把多个参数封装成一个Map,封装时使用的key是:通过@Param指定的key、param1param2....paramN

取值:#{@Param指定的key/param1param2....paramN}

例如:

操作:public Employee getEmpsLastNameAndIdNamedParameter(@Param("lastName") String lastName, @Param("Id") Integer id);

取值:#{lastName/param1}#{id/param2}

<select id="getEmpsLastNameAndIdNamedParameter" resultType="employee">
		select * from tbl_employee where last_name=#{param1} and id=#{param2}
	</select>
 
	<select id="getEmpsLastNameAndIdNamedParameter" resultType="employee">
		select * from tbl_employee where last_name=#{lastName} and id=#{id}
	</select>

4.Map 如果参数很多

但是不属于某个对象的属性,也是很常用,可以直接封装成map进行传递。

封装规则:Mybatis不做特殊处理,直接使用传递的Map

取值 :#{map中的key}

例如:public List<Employee> getEmpsByLastNameLikeAnsEmailLike(Map<String,Object> map);

<select id="getEmpsByLastNameLikeAnsEmailLike" resultType="employee">
		select * from tbl_employee where last_name like '${ln}' and email like
		'${email}'
	</select>
/*
	 * 5.如果参数很多,但不属于某个对象的属性,也不是很常用,可以直接封装成map进行传递 封装规则 Mybatis不做特殊处理 直接使用传递的map
	 * 取值 #{map中的key}
	 */
	@Test
	public void testMap() throws IOException {
		SqlSessionFactory ssf = getSqlSessionFactory();
		SqlSession sqlSession = ssf.openSession();
		Map<String, Object> map = new HashMap<String, Object>();
		map.put("ln", "%bq%");
		map.put("email", "%qq%");
		EmployeeMapper mapper = sqlSession.getMapper(EmployeeMapper.class);
		List<Employee> emps = mapper.getEmpsByLastNameLikeAnsEmailLike(map);
		System.out.println("使用map参数封装时的结果对象   " + emps);
	}

5.POJO ---> 传递单个对象

封装规则:Mybatis不做特殊处理

取值: #{POJO的属性名}

例如:

操作:public Integer addEmployee(Employee employee);

取值:#{employee的属性名idlastNameemailgender}

	<!--1. 字段名和属性名一一对应 2.parameter:确定传递参数的类型,也可以省略,mybatis会自动识别当前参数类型是什么 useGeneratedKeys:true使用自增主键的方式 
		keyProperty="id" 确定当前对象的哪个属性保存主键信息 保存自增主键值 -->
	<insert id="addEmployee" parameterType="com.hbsi.bean.Employee"
		useGeneratedKeys="true" keyProperty="id">
		insert into tbl_employee(last_name,email,gender)
		values(#{lastName},#{email},#{gender})
	</insert>

6.TO: Transfer Object数据传输对象

如果参数很多,但不属于某个对象的属性,却很常用,推荐写成java类,封装成对象进行传递

例如:在分页功能用的较多:封装成Page类{ int pageNo, int pageSize, int pages , boolean isHasPrevpage,boolean isHasNextPge......}

7.集合-------使用mybatis迭代

封装规则: MyBatis对 CollectionArray 会进行特殊处理, 也会封装Map。

封装的key:

  • Collection(List/Set):使用的key: collection
  • List :使用的key: collection/ list
  • Array:使用的key:array

例如:

操作:

public void deleteByExample(List<Integer> ids);

取值:(此时的key必须为list或collection)

<delete id="deleteByExample">
		delete from tbl_employee where id in
		<if test="_parameter!=null">
			<foreach close=")" collection="list" item="id" open="("
				separator=",">
				#{id}
			</foreach>
		</if>
	</delete>

集合-------使用mybatis迭代也可使 用@Param()来指定参数封装Map时所使用的key,多个参数也可以

操作

public void deleteByExample(@Param("listId")List<Integer> ids);

取值:此时的可以使用@Param("listId")指定的别名,listId

<delete id="deleteByExample">
		delete from tbl_employee where id in
		<if test="_parameter!=null">
			<foreach close=")" collection="listId" item="id" open="("
				separator=",">
				#{id}
			</foreach>
		</if>
	</delete>

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • SpringBoot集成极光推送完整实现代码

    SpringBoot集成极光推送完整实现代码

    本文主要介绍了SpringBoot集成极光推送完整实现代码,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-12-12
  • springboot内置tomcat调优并发线程数解析

    springboot内置tomcat调优并发线程数解析

    这篇文章主要介绍了springboot内置tomcat调优并发线程数解析,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • Java实现删除PDF中指定页面

    Java实现删除PDF中指定页面

    这篇文章主要为大家详细介绍了如何使用一个免费的国产Java库来删除PDF中的指定页面或者删除PDF中的空白页,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-11-11
  • Java多例Bean的应用场景-easyExcel导入

    Java多例Bean的应用场景-easyExcel导入

    EasyExcel 是一个基于 Java 的简单、省内存的读写 Excel 的开源项目。这篇文章主要介绍了用easyExcel导入Java Bean的应用场景,感兴趣的朋友可以参考阅读
    2023-04-04
  • cmd中javac命令无法运行(java指令能运行)解决步骤

    cmd中javac命令无法运行(java指令能运行)解决步骤

    这篇文章主要介绍了在安装JDK后,执行javac命令没有返回值的问题,可能是由于命令提示符窗口缓存问题、系统路径优先级问题、文件权限问题或命令行输入问题,文中通过代码将解决的步骤介绍的非常详细,需要的朋友可以参考下
    2025-02-02
  • SpringBoot基础教程之集成邮件服务

    SpringBoot基础教程之集成邮件服务

    这篇文章主要给大家介绍了关于SpringBoot基础教程之集成邮件服务的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者使用SpringBoot具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2020-07-07
  • Springboot单元测试无法读取配置文件的解决方案

    Springboot单元测试无法读取配置文件的解决方案

    这篇文章主要介绍了Springboot单元测试无法读取配置文件的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01
  • Springboot引入多个yml方法(多种方案)

    Springboot引入多个yml方法(多种方案)

    SpringBoot默认加载的是application.yml文件,所以想要引入其他配置的yml文件,就要在application.yml中激活该文件这篇文章主要介绍了Springboot引入多个yml方法,需要的朋友可以参考下
    2019-10-10
  • SpringCloud集成Eureka并实现负载均衡的过程详解

    SpringCloud集成Eureka并实现负载均衡的过程详解

    这篇文章主要给大家详细介绍了SpringCloud集成Eureka并实现负载均衡的过程,文章通过代码示例和图文讲解的非常详细,对大家的学习或工作有一定的参考价值,需要的朋友可以参考下
    2023-11-11
  • Java 事务注解@Transactional回滚(try catch、嵌套)问题

    Java 事务注解@Transactional回滚(try catch、嵌套)问题

    这篇文章主要介绍了Java @Transactional回滚(try catch、嵌套)问题,Spring 事务注解 @Transactional 本来可以保证原子性,如果事务内有报错的话,整个事务可以保证回滚,但是加上try catch或者事务嵌套,可能会导致事务回滚失败
    2022-08-08

最新评论