时间:2021-05-02
前言
现在大多项目都是使用mybatis了,但也有些公司使用hibernate。使用mybatis最大的特性就是sql需要自己写,而写sql就需要传递多个参数。面对各种复杂的业务场景,传递参数也是一种学问。
下面给大家总结了以下几种多参数传递的方法。
方法1:顺序传参法
#{}里面的数字代表你传入参数的顺序。
这种方法不建议使用,sql层表达不直观,且一旦顺序调整容易出错。
方法2:@param注解传参法
#{}里面的名称对应的是注解 @param括号里面修饰的名称。
这种方法在参数不多的情况还是比较直观的,推荐使用。
方法3:map传参法
#{}里面的名称对应的是 map里面的key名称。
这种方法适合传递多个参数,且参数易变能灵活传递的情况。
方法4:java bean传参法
#{}里面的名称对应的是 user类里面的成员属性。
这种方法很直观,但需要建一个实体类,扩展不容易,需要加属性,看情况使用。
使用mapper接口时参数传递方式
mybatis在使用mapper接口进行编程时,其实底层是采用了动态代理机制,表面上是调用的mapper接口,而实际上是通过动态代理调用的sqlsession的对应方法,如selectone(),有兴趣的朋友可以查看defaultsqlsession的getmapper()方法实现,其最终会获得一个代理了mapper接口的mapperproxy对象。mapperproxy对象在调用mapper接口方法时会把传递的参数做一个转换,然后把转换后的参数作为入参调用sqlsession对应的操作方法(如selectone、insert等)。转换过程可以参考mappermethod的execute()方法实现。简单来说是以下规则:
1、如果传递过来是单参数,且没有以@param注解进行命名,则直接将单参数作为真实的参数调用sqlsession的对应方法。
2、如果传递过来的不是单参数或者是包含以@param注解进行命名的参数,则会将对应的参数转换为一个map进行传递。具体规则如下:
2.1、 会把对应的参数按照顺序以param1、param2、paramn这样的形式作为key存入目标map中,第一个参数是param1,第n个参数是paramn。
2.2、 如果参数是以@param注解命名的参数,则以@param指定的名称作为key存入目标map中。
2.3、 如果参数不是以@param注解命名的,则按照顺序以0、1、n这样的形式作为key存入目标map中,第一个参数是0,第n个参数是n。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。
原文链接:http://zhuanlan.51cto.com/art/201804/571910.htm
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
小编给大家分享三种方案解决mybatis传递多个参数的问题,具体介绍如下所示:第一种方案DAO层的函数方法PublicUserselectUser(String
传递多个参数一般用在查询上,比如多个条件组成的查询,有以下方式去实现:版本信息:MyBatis:3.4.41、自带方法selectuser.id,user.us
PS:ibatis3如何传递多个参数有两个方法:一种是使用java.Map,另一种是使用JavaBean。当只向xxxMapper.xml文件中传递一个参数时,
问题描述:参数传递为List时:当传递一个List实例或者数组作为参数对象传给Mybatis。此时,Mybatis会自动将它包装在一个Map中,用名称在作为键。
main方法args参数用于接收用户输入的参数,参数以字符串形式存放在数组中。这里将传递参数参数的形式分两种,一种是传递普通参数,另一种是传递含有空格的参数。1