• MyBatis获取参数值的两种方式#{}和${} 以及 获取参数值的各种情况


    一、获取参数值的两种方式#{}和${}

    MyBatis 中,可以使用两种方式来获取参数值:#{} 和 ${}。

    1. #{}:这是 MyBatis 推荐使用的方式。在 SQL 语句中使用 #{},MyBatis 会自动将参数值进行预编译处理,防止 SQL 注入攻击,并且可以处理各种类型的参数(如字符串、数字、日期等)。例如:

    1. <select id="getUserById" resultType="User">
    2. SELECT * FROM user WHERE id = #{id}
    3. </select>

    在这个例子中,#{id} 表示一个参数占位符,MyBatis 会将它替换为具体的参数值。 

    2. ${}:这种方式会直接将参数值拼接到 SQL 语句中,不做预编译处理。这种方式适用于在 SQL 语句中引用列名、表名等无法使用 #{} 替换的情况。但需要注意的是,使用 ${} 可能会导致 SQL 注入攻击的风险,因此需要谨慎使用。例如:

    1. <select id="getUserByName" resultType="User">
    2. SELECT * FROM user WHERE name = '${name}'
    3. </select>

    MyBatis获取参数值的两种方式:${}和#{}
    ${}的本质就是字符串拼接,#{}的本质就是占位符赋值
    ${}使用字符串拼接的方式拼接sql,若为字符串类型或日期类型的字段进行赋值时,需要手动加单引号;但是#{}使用占位符赋值的方式,此时为字符串类型或日期类型的字段进行赋值时,可以自动添加单引号
     

    二、获取参数值的各种情况

    2.1   单个字面量类型的参数

    • 若mapper接口中的方法参数为单个的字面量类型,此时可以使用${}和#{}以任意的名称(最好见名识意)获取参数的值,注意${}需要手动加单引号
    1. <!--User getUserByUsername(String username);-->
    2. <select id="getUserByUsername" resultType="User">
    3. select * from t_user where username = #{username}
    4. </select>
    1. <!--User getUserByUsername(String username);-->
    2. <select id="getUserByUsername" resultType="User">
    3. select * from t_user where username = '${username}'
    4. </select>

    2.2  多个字面量类型的参数

    若mapper接口中的方法参数为多个时,此时MyBatis会自动将这些参数放在一个map集合中。
    ①  以arg0,arg1…为键,以参数为值;
    ②  以param1,param2…为键,以参数为值;
    因此只需要通过${}和#{}访问map集合的键就可以获取相对应的值,注意${}需要手动加单引号。
    使用arg或者param都行,要注意的是,arg是从arg0开始的,param是从param1开始的

    1. <!--User checkLogin(String username,String password);-->
    2. <select id="checkLogin" resultType="User">
    3. select * from t_user where username = #{arg0} and password = #{arg1}
    4. </select>
    1. <!--User checkLogin(String username,String password);-->
    2. <select id="checkLogin" resultType="User">
    3. select * from t_user where username = '${param1}' and password = '${param2}'
    4. </select>

    2.3  map集合类型的参数

    • 若mapper接口中的方法需要的参数为多个时,此时可以手动创建map集合,将这些数据放在map中只需要通过${}和#{}访问map集合的键就可以获取相对应的值,注意${}需要手动加单引号
    1. <!--User checkLoginByMap(Map<String,Object> map);-->
    2. <select id="checkLoginByMap" resultType="User">
    3. select * from t_user where username = #{username} and password = #{password}
    4. </select>
    1. @Test
    2. public void checkLoginByMap() {
    3. SqlSession sqlSession = SqlSessionUtils.getSqlSession();
    4. ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
    5. Map<String,Object> map = new HashMap<>();
    6. map.put("usermane","admin");
    7. map.put("password","123456");
    8. User user = mapper.checkLoginByMap(map);
    9. System.out.println(user);
    10. }

    2.4  实体类类型的参数

    • 若mapper接口中的方法参数为实体类对象时此时可以使用${}和#{},通过访问实体类对象中的属性名获取属性值,注意${}需要手动加单引号
    1. <insert id="insertUser">
    2. insert into t_user values(null,#{username},#{password},#{age},#{sex},#{email})
    3. insert>
    1. @Test
    2. public void insertUser() {
    3. SqlSession sqlSession = SqlSessionUtils.getSqlSession();
    4. ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
    5. User user = new User(null,"Tom","123456",12,"男","123@321.com");
    6. mapper.insertUser(user);
    7. }

    2.5  使用@Param标识参数

    可以通过@Param注解标识mapper接口中的方法参数,此时,会将这些参数放在map集合中

    1. 以@Param注解的value属性值为键,以参数为值;
    2. 以param1,param2…为键,以参数为值;
    • 只需要通过${}和#{}访问map集合的键就可以获取相对应的值,注意${}需要手动加单引号
    1. <!--User CheckLoginByParam(@Param("username") String username, @Param("password") String password);-->
    2. <select id="CheckLoginByParam" resultType="User">
    3. select * from t_user where username = #{username} and password = #{password}
    4. </select>
    1. @Test
    2. public void checkLoginByParam() {
    3. SqlSession sqlSession = SqlSessionUtils.getSqlSession();
    4. ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
    5. mapper.CheckLoginByParam("admin","123456");
    6. }

    三、总结

    • 建议分成两种情况进行处理
      1. 实体类类型的参数
      2. 使用@Param标识参数

    四、补贴知识点:以map集合接收作为返回值类型

    4.1  查询一条数据为map集合

    1. /**
    2. * 根据用户id查询用户信息为map集合
    3. * @param id
    4. * @return
    5. */
    6. Map<String, Object> getUserToMap(@Param("id") int id);
    1. <!--Map<String, Object> getUserToMap(@Param("id") int id);-->
    2. <select id="getUserToMap" resultType="map">
    3. select * from t_user where id = #{id}
    4. </select>
    5. <!--结果:{password=123456, sex=男, id=1, age=23, username=admin}-->

    4.2  查询多条数据为map集合

    4.2.1  方法一
    1. /**
    2. * 查询所有用户信息为map集合
    3. * @return
    4. * 将表中的数据以map集合的方式查询,一条数据对应一个map;若有多条数据,就会产生多个map集合,此时可以将这些map放在一个list集合中获取
    5. */
    6. List<Map<String, Object>> getAllUserToMap();
    1. <!--Map<String, Object> getAllUserToMap();-->
    2. <select id="getAllUserToMap" resultType="map">
    3. select * from t_user
    4. </select>
    5. <!--
    6. 结果:
    7. [{password=123456, sex=男, id=1, age=23, username=admin},
    8. {password=123456, sex=男, id=2, age=23, username=张三},
    9. {password=123456, sex=男, id=3, age=23, username=张三}]
    10. -->

    4.2.2  方法二
    1. /**
    2. * 查询所有用户信息为map集合
    3. * @return
    4. * 将表中的数据以map集合的方式查询,一条数据对应一个map;若有多条数据,就会产生多个map集合,并且最终要以一个map的方式返回数据,此时需要通过@MapKey注解设置map集合的键,值是每条数据所对应的map集合
    5. */
    6. @MapKey("id")
    7. Map getAllUserToMap();
    1. <!--Map<String, Object> getAllUserToMap();-->
    2. <select id="getAllUserToMap" resultType="map">
    3. select * from t_user
    4. </select>
    5. <!--
    6. 结果:
    7. {
    8. 1={password=123456, sex=男, id=1, age=23, username=admin},
    9. 2={password=123456, sex=男, id=2, age=23, username=张三},
    10. 3={password=123456, sex=男, id=3, age=23, username=张三}
    11. }
    12. -->

  • 相关阅读:
    什么是物联网数据采集网关?物联网数据采集网关的特点
    DBeaver 连接Hive-3.1.2
    01背包(换汤不换药)
    Java——Stream流的学习
    frp+docker内网穿透安装配置
    MFC 发起 HTTP Post 请求 发送MES消息
    四旋翼无人机学习第11节--页连接符与跨页连接符的使用
    VS2019+QT5.15调用动态库dll带有命名空间
    性能测试操作流程
    CAPL学习之路-DoIP相关函数
  • 原文地址:https://blog.csdn.net/weixin_55772633/article/details/132859377