原创

mybatis获取参数的5种方式

温馨提示:
本文最后更新于 2022年06月24日,已超过 2 天没有更新。若文章内的图片失效(无法正常加载),请留言反馈或直接联系我

1、单个字面量类型的参数

若mapper接口中的方法参数为单个的字面量类型,此时可以使用 ${} 和 #{} 以任意的名称(最好见名识意)获取参数的值,注意 ${} 需要手动加单引号

注:单个字面量类型的参数也可以使用下面的第五种 @Param 注解来获取,但是这时就只能通过 @Param 的值来获取参数

① 在 ParameterMapper 接口添加方法

/**
 * 根据用户名查询用户信息
 */
User getUserByUsername(String username);

② 在 ParameterMapper.xml 添加 SQL 语句

<!-- User getUserByUsername(String username) -->
<select id="getUserByUsername" resultType="User">
    <!-- ${}和#{}中的变量名可以任取, -->
    <!-- >select * from t_user where username = #{username} -->
    select * from t_user where username = '${username}' <!-- 注意${}外的单引号 -->
</select>

2、多个字面量类型的参数

若mapper接口中的方法参数为多个时,此时MyBatis会自动将这些参数放在一个map集合中,因此只需要通过${}和#{}访问map集合的键就可以获取相对应的值,注意${}需要手动加单引号。

使用arg或者param都行,要注意的是,arg是从arg0开始的,param是从param1开始的

  1. 以arg0,arg1...为键,以参数为值;
  2. 以param1,param2...为键,以参数为值;

arg 和 param 可以在同一个 SQL 语句中混合使用

① 在 ParameterMapper 接口添加方法

/**
 * 验证登录
 */
User checkLogin(String username, String password);

② 在 ParameterMapper.xml 添加 SQL 语句

<!-- User checkLogin(String username, String password) -->
<select id="checkLogin" resultType="User">
    <!-- select * from t_user where username = #{arg0} and password = #{param2} -->
    select * from t_user where username = '${arg0}' and password = '${param2}'
</select>

3、map 集合类型的参数

若 mapper 接口中的方法需要的参数为多个时,此时可以手动创建 map 集合,将这些数据放在map中只需要通过 ${} 和 #{} 访问map集合的键就可以获取相对应的值,注意 ${} 需要手动加单引号

① 在 ParameterMapper 接口添加方法

/**
 * 验证登录(参数为 map)
 */
User checkLoginByMap(Map<String, Object> map);

② 在 ParameterMapper.xml 添加 SQL 语句

<!-- User checkLoginByMap(Map<String, Object> map) -->
<select id="checkLoginByMap" resultType="User">
    <!-- select * from t_user where username = #{username} and password = #{password} -->
    select * from t_user where username = '${username}' and password = '${password}'
</select>

4、实体类类型参数

若 mapper 接口中的方法参数为实体类对象时此时可以使用 ${} 和 #{},通过访问实体类对象中的属性名获取属性值,注意 ${} 需要手动加单引号

① 在 ParameterMapper 接口添加方法

/**
 * 添加用户信息
 */
int insertUser(User user);

② 在 ParameterMapper.xml 添加 SQL 语句

<!-- int insertUser(User user) -->
<insert id="insertUser">
    insert into t_user values(null, #{username}, #{password}, #{age}, #{sex}, #{email})
</insert>

5、使用 @param 表示参数(部分源码分析)

可以通过@Param注解标识mapper接口中的方法参数,此时,会将这些参数放在map集合中(以 @Param 中的值为键,参数为值 或 以param1,param2,... 为键,参数为值),只需要通过${}和#{}访问map集合的键就可以获取相对应的值,注意${}需要手动加单引号

① 在 ParameterMapper 接口添加方法

/**
 * 验证登录(使用@param注解)
 */
User checkLoginByParam(@Param("username") String username, @Param("password") String password);

② 在 ParameterMapper.xml 添加 SQL 语句

<!-- User checkLoginByParam(@Param("username") String username, @Param("password") String password) -->
<select id="checkLoginByParam" resultType="User">
    select * from t_user where username = #{username} and password = #{password}
</select>

③ 在测试类中进行测试

@Test
public void testCheckLoginByParam(){
    SqlSession sqlSession = SqlSessionUtils.getSqlSession();
    ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
    User admin = mapper.checkLogin("admin", "123456");
    System.out.println(admin);
}

其实我们可以将以上几种方式都归结为两种方式一种是对象方式获取参数,一种是以@param方式获取参数
尚硅谷资料下载

正文到此结束