首页 > 其他分享 >5. Mybatis获取参数值的两种方式

5. Mybatis获取参数值的两种方式

时间:2023-06-04 18:24:06浏览次数:35  
标签:语句 map mapper sql 获取 参数 SQL Mybatis 参数值

MyBatis 获取参数值的两种方式:${} 和 #{}

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

#{}:先编译 sql 语句,再给占位符传值,底层是 PreparedStatement 实现。可以防止 sql 注入,比较常用。

${}:先进行 sql 语句拼接,然后再编译 sql 语句,底层是 Statement 实现。存在 sql 注入现象。只有在需要进行 sql 语句关键字拼接的情况下才会用到。

Mybatis 中的 ${}​ 和 #{}​ 都是用于 SQL 语句中参数的替代。

#{}​ 使用的是预编译语句,用于将输入参数的值与 SQL 语句分开处理,防止 SQL 注入等安全问题,同时也有效的提高了 SQL 语句的查询性能。在 SQL 解析过程中,#{} 会将参数值进行一定的处理,比如转义特殊字符、处理成相应的数据类型等。

$ {}​ 在 SQL 中是直接替换为参数的值,不做任何转义和修改。这种方式的优点是灵活性强,可以用于不同的场景,但是这种方式存在 SQL 注入的风险,因为输入的参数被直接拼接到 SQL 语句中,如果不充分防范,很容易被攻击者利用。

一般情况下,使用 #{}​ 是比较安全的方式,但是如果在某些特殊的情况下,确实需要使用 ${}​,比如在动态 SQL 中,将一些动态的 SQL 拼接到主 SQL 中。

综上所述,#{}​ 适用于大多情况下,比如查询、更新等;而 ${}​ 适用于某些特殊情况,比如动态 SQL,但是需要注意 SQL 注入的问题。

使用方式示例:

  • #{}​:
<select id="getUserById" resultType="User">
  select * from user where id = #{id}
</select>
Map<String, Object> param = new HashMap<>();
param.put("id", 1);
User user = sqlSession.selectOne("getUserById", param);
  • ${}​:
<!-- 动态 SQL 标签 -->
<select id="getUserByCondition" resultType="User">
  select * from user where
  <if test="name != null">
    name = '${name}'
  </if>
  <if test="age != null">
    and age = '${age}'
  </if>
</select>
Map<String, Object> param = new HashMap<>();
param.put("name", "John Doe");
param.put("age", 20);
User user = sqlSession.selectOne("getUserByCondition", param);

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

  • 若 mapper 接口中的方法参数为单个的字面量类型

  • 此时可以使用\({}和#{}以任意的名称获取参数的值,注意\){}需要手动加单引号

image

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

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

image

3. map 集合类型的参数

  • 若 mapper 接口中的方法需要的参数为多个时,此时可以手动创建 map 集合,将这些数据放在 map 中

  • 只需要通过\({}和#{}访问map集合的键就可以获取相对应的值,注意\){}需要手动加单引号

image

image

代码实现:

    @Test
    public void testCheckLoginMap() {
        SqlSession sqlSession = SqlSessionUtil.getSqlSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        Map<String, Object> map = new HashMap<>();
        map.put("username", "zhangsan");
        map.put("password", "123456");
        User user = mapper.checkLoginMap(map);
        System.out.println(user);
        sqlSession.close();
    }

4. 实体类类型的参数

若 mapper 接口中的方法参数为实体类对象时 , 此时可以使用${}和#{},通过访问实体类对象中的属性名获取属性值

注意 :

  • ${} 需要手动添加单引号

根据属性名获取属性值

  • 这里的属性名指的是实体类当中get后面的名字​ , 就像 getAge 而这里的属性名值得就是 age , 大小写无所谓

    image

5. 使用@Param 标识参数

可以通过@Param 注解标识 mapper 接口中的方法参数, 此时会将这些参数放在 map 集合中,以@Param 注解的 value 属性值为键,以参数为值;以 param1,param2...为键,以参数为值;只需要通过${}和#{}访问 map 集合的键就可以获取相对应的值

注意${}需要手动加单引号

image

标签:语句,map,mapper,sql,获取,参数,SQL,Mybatis,参数值
From: https://www.cnblogs.com/NorthPoet/p/17456040.html

相关文章

  • 6. Mybatis的各种查询功能
    6.1、查询一个实体类对象‍/***根据用户id查询用户信息*@paramid*@return*/UsergetUserById(@Param("id")intid);<!--UsergetUserById(@Param("id")intid);--><selectid="getUserById"resultType="User">select*......
  • spring整合mybatisplus
    配置文件注解配置mapper扫描:@MapperScan("com.bjsxt.mybatisplus_lombok_swagger.mapper")pom<dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency><!--mybatisp......
  • 【电商api接口京东系列】获取推荐商品列表+获得商品评论演示示例
    数据采集是指获取和整理各种数据的过程,这些数据可以来自各种来源,例如互联网、社交媒体、传统媒体、设备传感器、企业内部系统等。通常,数据采集是企业或组织重要的商业活动之一。它可以帮助企业了解客户需求、产品趋势、市场机会,以及竞争对手的情况,进而做出更加明智的商业决策。......
  • springboot整合mybatis
    整合mybatis基础配置启动类添加@MapperScan配置文件#=================================数据库相关配置====================================spring.datasource.driver-class-name=com.mysql.jdbc.Driverspring.datasource.url=jdbc:mysql://10.1.1.1:3306/db?useUnico......
  • 逆向思维获取他人信任
    以往的做法以往的做法往往是尽量收集受害人信息,从而简历与受害人之间的信任,随着人们对个人信息的重视以及官方对诈骗分子的宣传,大部分人都拥有极高的警惕性,而且收集一个人尽可能多的信息从而应对各种***钻古怪的问题并不容易,这样的成本显然是极高的。反向建立自己与受害人之间的......
  • aop操作-环绕通知获取数据的案例
    添加ResourcesService,ResourcesServiceImpl,ResourcesDao和ResourcesDaoImpl类publicinterfaceResourcesDao{booleanreadResources(Stringurl,Stringpassword);}@RepositorypublicclassResourcesDaoImplimplementsResourcesDao{publicbooleanreadRe......
  • 2. 搭建Mybatis
    确认开发环境​MySQL不同版本的注意事项1、驱动类driver-class-nameMySQL5版本使用jdbc5驱动,驱动类使用:com.mysql.jdbc.DriverMySQL8版本使用jdbc8驱动,驱动类使用:com.mysql.cj.jdbc.Driver2、连接地址urlMySQL5版本的url:jdbc:mysql://localhost:3306/ssmMySQL8版......
  • Spring和MyBatis整合
    框架整合时三层架构的分工  进行SSM框架整合时,两个框架的分工如下所示。MyBatis负责与数据库进行交互。Spring负责事务管理,Spring可以管理持久层的Mapper对象及业务层的Service对象。由于Mapper对象和Service对象都在Spring容器中,所以可以在业务逻辑层通过Service对象调用......
  • Spring整合mybatis使用xml配置事务
    自己准备开始教授Java相关的技术,Spring框架是必须让学生学习的框架之一。里面有一个事务的配置以前刚学习Spring框架的时候有接触过,不过已经过了很多年,很多东西都已经忘记。现在再来回忆一下如何使用Spring框架类配置事务。使用到的maven坐标如下:<dependencies>    <......
  • MyBatis之一对多抓取策略
    MyBatis之一对多抓取策略1.情况描述如果只需要使用一方中的数据,而不使用多方数据的情况下,在执行过程中不需要发送查询多方的sql语句,需要配置抓取策略为懒加载。2.适用情况适用于一对多的方式一,通过多条sql查询情况。3.抓取策略fetchType(映射文件collection集合映射标签内......