【面试题-013】MyBatis 中,`#` 和 `$` 符号区别

在 MyBatis 中,#$ 符号用于参数替换和表达式。它们在 SQL 语句中用于防止 SQL 注入,并允许动态地插入参数值。

  1. # 符号(预编译参数):
    • #{parameter} 用于预编译参数。
    • 在 SQL 语句中,#{parameter} 会被 MyBatis 解析为一个参数占位符,MyBatis 会自动将参数值进行转义,以防止 SQL 注入。
    • 预编译参数适合用于简单的字符串替换,如查询和更新操作。
  2. $ 符号(动态参数):
    • ${parameter} 用于动态参数。
    • 在 SQL 语句中,${parameter} 会被 MyBatis 解析为一个动态参数。
    • 动态参数允许你直接在 SQL 语句中插入变量值,而不需要进行转义。
    • 动态参数适合用于复杂的表达式和计算,如拼接字符串、计算等。
      总结:
  • #{parameter} 是 MyBatis 推荐的参数替换方式,用于防止 SQL 注入,并提供了更好的安全性。
  • ${parameter} 虽然允许直接插入变量值,但需要注意 SQL 注入的风险,并确保变量值的安全性。
    在实际应用中,应该优先使用 #{parameter} 进行参数替换,以提高代码的安全性和可维护性。

MyBatis 中的缓存机制主要包括一级缓存和二级缓存

MyBatis 中的缓存机制主要包括一级缓存和二级缓存。它们的作用和实现方式有所不同,下面详细介绍:

一级缓存(SqlSession 缓存)

  1. 作用
    • 一级缓存是 SqlSession 级别的缓存,它存储了最近一次查询的结果。
    • 每个 SqlSession 都有自己的缓存,缓存中存储了查询结果
  2. 存储内容
    • 存储的是查询的结果集,包括从数据库中检索到的数据。
  3. 存储方式
    • 缓存存储在 SqlSession 中,因此同一个 SqlSession 内的所有查询都会共享这个缓存
  4. 缓存策略
    • 默认情况下,一级缓存是开启的,除非在映射器 XML 文件中或 MyBatis 配置文件中明确关闭。
  5. 失效时机
    • 当 SqlSession 关闭时,一级缓存中的数据会被清空。
    • 如果查询的结果集被修改,或者查询的 SQL 语句发生了变化,一级缓存中的数据也会被清空。

二级缓存(Mapper 缓存)

  1. 作用
    • 二级缓存是跨多个 SqlSession 的缓存,它可以存储多个 SqlSession 的查询结果
    • 二级缓存可以提高多个 SqlSession 之间查询结果的共享和复用
  2. 存储内容
    • 存储的是查询的结果集,与一级缓存类似。
  3. 存储方式
    • 缓存存储在 Mapper 接口的实现类中,而不是 SqlSession 中。
    • 同一个 Mapper 接口的实现类之间共享二级缓存。
  4. 缓存策略
    • 默认情况下,二级缓存是关闭的,除非在映射器 XML 文件中或 MyBatis 配置文件中明确开启。
    • 开启二级缓存后,可以设置具体的缓存实现类,如 org.apache.ibatis.cache.impl.PerpetualCache
  5. 失效时机
    • 当 Mapper 接口的实现类(代理类)被垃圾回收时,二级缓存中的数据会被清空。
    • 如果查询的结果集被修改,或者查询的 SQL 语句发生了变化,二级缓存中的数据也会被清空。

总结

  • 一级缓存适用于单次会话内的查询结果缓存,可以提高会话内的查询效率。
  • 二级缓存适用于跨多个会话的查询结果缓存,可以提高不同会话之间的查询效率。
    在使用 MyBatis 时,可以根据实际需求来选择使用一级缓存、二级缓存,或者两者结合使用。同时,需要注意缓存策略的设置,以避免缓存带来的问题,如脏数据、数据不一致等。
相关推荐
小灰灰要减肥25 分钟前
装饰者模式
java
张铁铁是个小胖子37 分钟前
MyBatis学习
java·学习·mybatis
Yan.love1 小时前
开发场景中Java 集合的最佳选择
java·数据结构·链表
椰椰椰耶1 小时前
【文档搜索引擎】搜索模块的完整实现
java·搜索引擎
大G哥1 小时前
java提高正则处理效率
java·开发语言
智慧老师2 小时前
Spring基础分析13-Spring Security框架
java·后端·spring
lxyzcm2 小时前
C++23新特性解析:[[assume]]属性
java·c++·spring boot·c++23
V+zmm101342 小时前
基于微信小程序的乡村政务服务系统springboot+论文源码调试讲解
java·微信小程序·小程序·毕业设计·ssm
Oneforlove_twoforjob3 小时前
【Java基础面试题025】什么是Java的Integer缓存池?
java·开发语言·缓存
xmh-sxh-13143 小时前
常用的缓存技术都有哪些
java