【面试题-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 时,可以根据实际需求来选择使用一级缓存、二级缓存,或者两者结合使用。同时,需要注意缓存策略的设置,以避免缓存带来的问题,如脏数据、数据不一致等。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/20903.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【C/C++】C++类的六个特殊成员函数,附亲测实例

在C中,类的特殊成员函数是指那些由编译器自动生成的函数,它们在特定情况下会被调用,以支持类的某些操作。这些特殊成员函数包括: 默认构造函数(Default Constructor): 当没有提供任何构造函数时…

【C++】C++程序的四个区和智能指针的实现

这篇文章介绍下 C 程序的四个区,以及一个智能指针的简单实现。 起因 最近在公司审查代码的时候,coverity 对以下代码: T fun() {Obj obj;//代码逻辑 }报出了 obj 占用空间过大,有可能栈溢出的问题。 以前从来没有考虑过C的代码…

双指针练习:盛水最多的容器

题目链接:11.盛水最多的容器 题目描述: 给定一个长度为 n 的整数数组 height 。有 n 条垂线,第 i 条线的两个端点是 (i, 0) 和 (i, height[i]) 。 找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。 返回容器可…

【多模态】34、LLaVA-v1.5 | 微软开源,用极简框架来实现高效的多模态 LMM 模型

文章目录 一、背景二、方法2.1 提升点2.2 训练样本 三、效果3.1 整体效果对比3.2 模型对于 zero-shot 形式的指令的结果生成能力3.3 模型对于 zero-shot 多语言的能力3.4 限制 四、训练4.1 数据4.2 超参 五、代码 论文:Improved Baselines with Visual Instruction …

深入了解 Java 泛型

Java 泛型(Generics)是 Java SE 5 引入的一个强大特性,它允许你定义类、接口和方法时使用类型参数,从而使代码更加灵活和可重用。本篇博客将详细讲解 Java 泛型的概念、使用方法和注意事项,并通过多个代码示例&#xf…

回溯算法指组合总和

题目: 找出所有相加之和为 n 的 k 个数的组合,且满足下列条件: 只使用数字1到9每个数字 最多使用一次 返回 所有可能的有效组合的列表 。该列表不能包含相同的组合两次,组合可以以任何顺序返回。 思路: 这种问题…

python编程:SQLite 管理图片数据库

在本博客中,我们将介绍如何使用 wxPython 和 sqlite3 模块构建一个 GUI 应用程序,该程序可以遍历指定文件夹中的所有图片,并将其信息存储到 SQLite 数据库中。 C:\pythoncode\new\InputImageOFFolderTOSqlite.py 项目简介 我们的目标是创建…

【无标题】2024.6.2

2024.6.2 【明霄升海平,飞彩镌流年。】 Sunday 四月廿六 A. 矩形覆盖 题目描述 有N个矩形,矩形的底边边长为1,且均在X轴上,高度给出,第i个矩形的高为h[i],求最少需要几个矩形才能覆盖这个图形。 例如h […

微信里的东西怎么打印出来呢

随着微信的普及,我们的日常生活和工作都离不开这个强大的社交工具。无论是重要的工作文件、孩子的作业、还是精彩的旅行照片,我们都习惯在微信里保存和分享。但是,当需要将这些微信里的内容打印出来时,很多人可能会感到困惑和麻烦…

2024.05.18 校招 实习 内推 面经

绿*泡*泡VX: neituijunsir 交流*裙 ,内推/实习/校招汇总表格 1、实习 | 东风日产2024实习生招聘正式启动 实习 | 东风日产2024实习生招聘正式启动 2、实习 | 达实智能实习生招募令! 实习 | 达实智能实习生招募令! 3、校招 | …

电力能源指挥中心调度台解决方案主要关注的问题

调度台是指挥中心不可或缺的设备,随着信息化建设的不断深入,电力能源指挥中心已成为重要平台。因此,构建一套高效、智能的电力能源指挥中心调度台解决方案,需要关注以下关键问题: 一、实时监控与数据采集 电力能源指挥…

2.3.2_3 单链表的建立

喜欢《数据结构》部分笔记的小伙伴可以订阅专栏,今后还会不断更新。 此外,《程序员必备技能》专栏和《程序员必备工具》专栏(该专栏暂未开设)日后会逐步更新,感兴趣的小伙伴可以点一下订阅、收藏、关注! 谢…

【AI 大揭秘】ChatGPT 写作绝技与必备提示词大全

利用ChatGPT撰写文章是一种极具创意的方法,它能显著提升您的写作效率,并帮助您创作出高质量的内容。通过人工智能的辅助,您可以迅速、便捷地生成精美文章,或至少为您的下一个写作项目提供灵感。 不管您是在撰写文章、剧本还是电子…

react路由参数path不再支持正则?比较v5和v6写法的差异性

文章目录 前言v5方式:直接在path参数中,写入对应正则(1)代码详细注释如下(2)页面输出如下,会出现undefined的情况 v6方式: 在路由对象中配置,但只可配动态路由,不可用正则…

TH方程学习(4)

一、背景介绍 在本节将会对TH方程打包成一个函数,通过输入目标星的轨道要素,追踪星在目标星VVLH坐标系下的相对位置和速度,以及预报的时间,得到预报时刻追踪星在VVLH坐标系下的位置和速度,以及整个状态转移矩阵。 合并…

替换所有的问号 ---- 模拟

题目链接 题目: 分析: 我们只需要遍历字符串, 将所有?进行修改即可但是需要判断, 修改的字符不能和前面后面重复同时, 有一个细节需要处理, 就是当?在最前面时, 没有前面的符号需要判断 在最后面的时候, 没有后面的字符需要判断 代码: class Solution {public String mod…

Django ORM深度游:探索多对一、一对一与多对多数据关系的奥秘与实践

系列文章目录 Django入门全攻略:从零搭建你的第一个Web项目Django ORM入门指南:从概念到实践,掌握模型创建、迁移与视图操作Django ORM实战:模型字段与元选项配置,以及链式过滤与QF查询详解Django ORM深度游&#xff…

面试题--this关键字

this 指向是前端面试中的常问题型,简单分析为以下几种: 1. 在全局作用域中,this 关键字固定指向全局对象 window 或者 global。 2. 在函数作用域中,取决于函数是如何被调用的。 1)函数直接调用,this 指向…

Leetcode 3169. Count Days Without Meetings

Leetcode 3169. Count Days Without Meetings 1. 解题思路2. 代码实现 题目链接:3169. Count Days Without Meetings 1. 解题思路 这一题的话我们只需要先对meeting的时间进行一下排序,然后不断更新当前连续开会的时间即可。当某一个会议开始时&#…

Java中lambda表达式是啥怎么使用

在Java中,Lambda表达式(也称为闭包)是一种简洁地表示匿名函数(即没有名称的函数)的方式。它们允许你将函数作为参数传递或赋值给变量,从而简化代码。Lambda表达式在Java 8及更高版本中引入。 Lambda表达式…