方式 1 :封装成对象入参  #{对应实体类的属性}

 //UserMapper.java 接口

 /**
* 多条件查询:根据用户名称(模糊查询)和用户角色查询用户列表(参数:对象入参)
* @param user 对象入参
* @return
*/
public List<User> getUserListByUserNameAndUserRole(User user); //UserMapper.xml SQL 映射文件 <!--多条件查询:根据用户名称(模糊查询)和用户角色查询用户列表 (参数:对象入参); 参数传递:#{属性名}(参数对象中的属性名) -->
<select id="getUserListByUserNameAndUserRole" resultType="user" parameterType="user">
SELECT * FROM smbms_user WHERE userName LIKE CONCAT('%',#{userName},'%') AND userRole=#{userRole}
</select> //单元测试类 UserMapperTest.java
@Test // 测试多条件查询:根据用户名称(模糊查询)和用户角色查询用户列表(参数:对象入参)
public void testGetUserListByUserNameAndUserRole() {
List<User> userList = null;
User user = new User();
user.setUserName("孙");
user.setUserRole(3);
userList = session.getMapper(UserMapper.class).getUserListByUserNameAndUserRole(user);
for (User u : userList) {
System.out.println(u);
}
}

  说明:1、parameterType 使用了复杂数据类型,把条件参数封装成 User 对象进行入参。  2、#{属性名}里面的名称对应的是 User 实体类里面的成员属性。

方式 2 :封装成 Map 对象入参  #{对应的是 Map 里面的 key 名称}

//UserMapper.java 接口
   /**
* 多条件查询:根据用户名称(模糊查询)和用户角色查询用户列表(参数:Map 对象入参)
* @param userMap Map 对象入参
* @return
*/
public List<User> getUserListByUserNameAndUserRole(Map<String, Object> userMap);
//UserMapper.xml SQL 映射文件
<!--多条件查询:根据用户名称(模糊查询)和用户角色查询用户列表  (参数:Map 对象入参); 参数传递:#{Map 的 key} -->
<select id="getUserListByUserNameAndUserRole" resultType="user" parameterType="map">
SELECT * FROM smbms_user WHERE userName LIKE CONCAT('%',#{uName},'%') AND userRole=#{uRole}
</select>
//单元测试类 UserMapperTest.java
    @Test // 测试多条件查询:根据用户名称(模糊查询)和用户角色查询用户列表(参数:Map 对象入参)
public void testGetUserListByUserNameAndUserRole() {
List<User> userList = null; Map<String, Object> userMap=new HashMap<String, Object>();
userMap.put("uName", "孙");
userMap.put("uRole", 3);
userList = session.getMapper(UserMapper.class).getUserListByUserNameAndUserRole(userMap);
for (User u : userList) {
System.out.println(u);
}
}

  说明:Map 传参比较灵活,不管什么类型参数,或者多少个参数,都可以吧它封装成 Map 数据结构进行入参,通过 Map 的 key 即可获取传入的值。

方式 3 :使用 @Param 注解实现多参数入参   #{对应 @param 注解里面的值}

//UserMapper.java 接口
   /**
* 多条件查询:根据用户名称(模糊查询)和用户角色查询用户列表(参数:@Param 注解入参)
* @param userName 用户名称
* @param userRole 用户角色
* @return
*/
public List<User> getUserListByUserNameAndUserRole(@Param("name")String userName,@Param("role")int userRole);
//UserMapper.xml SQL 映射文件
<!--多条件查询:根据用户名称(模糊查询)和用户角色查询用户列表(参数:@Param 注解入参); 参数传递:#{对应 @param 注解里面的值}-->
<select id="getUserListByUserNameAndUserRole" resultType="user" >
SELECT * FROM smbms_user WHERE userName LIKE CONCAT('%',#{name},'%') AND userRole=#{role}
</select>
//单元测试类 UserMapperTest.java
    @Test // 测试多条件查询:根据用户名称(模糊查询)和用户角色查询用户列表(参数:@Param 注解入参)
public void testGetUserListByUserNameAndUserRole() {
List<User> userList = null;
String userName="孙";
int userRole=3;
userList = session.getMapper(UserMapper.class).getUserListByUserNameAndUserRole(userName, userRole);
for (User u : userList) {
System.out.println(u);
}
}

  说明:

     1、使用 @param 注解直接实现多参数入参,代码可读性高,可以清晰地看出这个接口方法所需的参数是什么。

     2、使用 @param 注解直接实现多参数入参,相当于将参数重命名为注解名称,在映射的 SQL 中需要使用 #{注解名称} 。

       3、在 MyBatis 中参数入参,何时需要封装成对象入参,何时又需要使用多参数入参(即 @param 注解入参)?

       答:一般情况下,超过 4 个以上的参数最好封装成对象入参(特别是在常规的增加和修改操作时,字段较多,封装成对象比较方便)。
        对于参数固定的业务方法,最好使用多参数入参,原因是这种方法比较灵活,代码的可读性高,可以清晰地看出接口方法中所需的参数是什么。并且对于固定的接口方法,参数一般是固定的,所以直接多参数入参即可,无须封装对象。
        需要注意的是,当参数为基础数据类型时,不管是多参数入参,还是单独的一个参数入参,都需要使用 @Param 注解来进行参数的传递。

    

方式 4 :使用下标传参   #{对应传入参数的顺序,下标从 0 开始}

//UserMapper.java 接口
  /**
* 多条件查询:根据用户名称(模糊查询)和用户角色查询用户列表(参数:使用下标传参)
* @param userName 用户名称
* @param userRole 用户角色
* @return
*/
public List<User> getUserListByUserNameAndUserRole(String userName,int userRole);
//UserMapper.xml SQL 映射文件
<!--多条件查询:根据用户名称(模糊查询)和用户角色查询用户列表(参数:使用下标传参); 参数传递:#{对应传入参数的顺序,下标从 0 开始}-->
<select id="getUserListByUserNameAndUserRole" resultType="user" >
SELECT * FROM smbms_user WHERE userName LIKE CONCAT('%',#{0},'%') AND userRole=#{1}
</select>
//单元测试类 UserMapperTest.java
    @Test // 测试多条件查询:根据用户名称(模糊查询)和用户角色查询用户列表(参数:使用下标传参)
public void testGetUserListByUserNameAndUserRole() {
List<User> userList = null;
String userName="孙";
int userRole=3;
userList = session.getMapper(UserMapper.class).getUserListByUserNameAndUserRole(userName, userRole);
for (User u : userList) {
System.out.println(u);
}
}

  说明:#{ }里面的数字代表你传入参数的顺序,下标从 0 开始。

MyBatis 中传递多个参数的 4 种方式的更多相关文章

  1. Mybatis传递多个参数的4种方式(干货)

    Mybatis传递多个参数的4种方式(干货)-----https://blog.csdn.net/youanyyou/article/details/79406486

  2. Mybatis中使用association进行关联的几种方式

    这里以一对一单向关联为例.对使用或不使用association的配置进行举例.  实体类: @Data @ToString @NoArgsConstructor public class IdCard ...

  3. Mybatis中传递多个参数的方法总结

    一.单个参数: public List<XXBean> getXXBeanList(String xxCode); <select id="getXXXBeanList&q ...

  4. Mybatis传递多个参数的几种方式

    顺序传参法 public User selectUser(String name, int deptId); <select id="selectUser" resultMa ...

  5. mybatis中mapper接口的参数设置几种方法

    方法一:忽略parameterType,加@param("xxx")注解 在mapper接口中加上@param("xxx")注解,则在配置文件中直接用即可 Li ...

  6. MyBatis 示例-传递多个参数

    映射器的主要元素: 本章介绍 select 元素中传递多个参数的处理方式. 测试类:com.yjw.demo.MulParametersTest 使用 Map 传递参数(不建议使用) 使用 MyBat ...

  7. Delphi过程函数传递参数的几种方式

    Delphi过程函数传递参数的几种方式  在Delphi过程.函数中传递参数几个修饰符为Const.Var.Out. 另一种不加修饰符的为默认按值传递参数. 一.默认方式以值方式传递参数 proced ...

  8. asp传递参数的几种方式

    把下列代码分别加入a.asp和b.asp的<body></body>中,点提交,就可以将a.asp文本框的内容传给b.asp并显示出来 a.ASP <form actio ...

  9. Dojo初探之2:设置dojoConfig详解,dojoConfig参数详解+Dojo中预置自定义AMD模块的四种方式(基于dojo1.11.2)

    Dojo中想要加载自定义的AMD模块,需要先设置好这个模块对应的路径,模块的路径就是这个模块的唯一标识符. 一.dojoConfig参数设置详解 var dojoConfig = { baseUrl: ...

随机推荐

  1. 逻辑频道号---DVB NIT LCN

    先介绍NIT,NIT描述如下: 有一点要注意,NIT是对大网的描述,即NIT并不是描述当前的流,而是描述大网的某些或者全部流.如下图,TS流描述1-6共对6个频点不同的TS流进行了描述,具体对哪一个流 ...

  2. 在WIN7里IE8的开发人员工具打不开的解决办法

    IE8新增了开发人员工具,非常不错,比早期的DevToolbar好用多了.不过在我的Win7下使用的时候偶尔会出现一个莫名其妙的问题,就是整个开发人员工具窗口消失了,打不开了.当你使用win+Tab切 ...

  3. 15_activity生命周期方法说明

    现在是可见并且可以被操作,所以现在是一个前台的Activity. 按一下Home键,它是先onPause然后onStop. 现在它就处于一个Stop停止的状态.停止的状态如果我当前内存够用的情况下,它 ...

  4. Permutations II 典型去重

    https://leetcode.com/problems/permutations-ii/ Given a collection of numbers that might contain dupl ...

  5. js获取标签的三种方式

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  6. python自动化测试学习笔记-9python的日志模块

    参考 logging模块,用来处理python中的日志: import logging logging.debug('debug')logging.info('info')logging.warnin ...

  7. daily_journal_3 the game of thrones

    昨晚追完了最爱的美剧(the game of thrones),哇,看到结局有点崩溃.果然还是美帝淫民开放,各种乱伦,在七夕收到的万点暴击就祝天下有情人就像剧中一样终是血亲. 昨天算是完成了git的复 ...

  8. STL---vector的内存分配策略

    2级策略,过程如下: 第一级 __malloc_alloc_template内存分配器 该分配器是对malloc.realloc以及free的封装: 第二级  __default_alloc_temp ...

  9. 287 Find the Duplicate Number 寻找重复数

    一个长度为 n + 1 的整形数组,其中的数字都在 1 到 n 之间,包括 1 和 n ,可知至少有一个重复的数字存在.假设只有一个数字重复,找出这个重复的数字.注意:    不能更改数组内容(假设数 ...

  10. 项目需求会__前端er定位的思考~

    一.页面展示-----针对前端部分:后台的东西(功能.样式)不考虑! 二.动态效果------能不能实现! 三.接口数据------怎么传数据! 四.兼容性--------兼容到哪个版本浏览器! 五. ...