高级java每日一道面试题-2024年9月04日-框架篇(Mybatis篇)-mybatis中的#{}和${}的区别是什么?

embedded/2024/9/23 6:28:50/

如果有遗漏,评论区告诉我进行补充

mybatis_1">面试官: mybatis中的#{}和${}的区别是什么?

我回答:

在MyBatis中,#{}${} 是两种用于参数替换的占位符,它们在SQL语句中的使用方式和作用有所不同,主要体现在安全性、类型处理和预编译SQL语句的处理上。

1. #{}(预处理占位符)

  • 安全性#{} 使用了预处理(PreparedStatement)的方式,有效防止了SQL注入攻击。因为预处理语句在发送SQL语句到数据库之前,会将SQL语句中的参数替换成占位符(如?),然后在执行时再传入具体的参数值。这样,即使参数中包含SQL注入的恶意代码,也不会被数据库执行。MyBatis会将传入的参数值自动加上引号,如果是数字类型,则直接插入,如果是字符串类型,则加上单引号。

  • 类型处理:MyBatis 会对#{}替换的参数进行必要的类型转换和转义处理,以确保参数的类型与数据库表中的列类型相匹配。

  • 预编译SQL:使用#{}的SQL语句在数据库层面会被预编译,这意味着如果同一个SQL语句(仅仅是参数不同)被多次执行,数据库会重用之前的预编译结果,这有助于提高性能

2. ${}(字符串替换)

  • 安全性${} 是简单的字符串替换,直接将参数值拼接到SQL语句中。这种方式容易受到SQL注入攻击,因为参数值会被直接解析为SQL语句的一部分。如果参数值中包含SQL语句的片段,那么这些片段将作为SQL语句的一部分被执行。

  • 类型处理${} 不会进行类型处理或转义处理,它仅仅是将参数值转换成字符串(如果参数不是字符串的话),然后直接拼接到SQL语句中。

  • 预编译SQL:使用${}的SQL语句不使用预编译SQL,因为每次执行时SQL语句本身都可能不同(取决于参数值)。这可能导致性能下降,特别是在执行大量相似但参数不同的SQL语句时。

  • 灵活性:使用${}可以提高SQL语句的灵活性,特别是在需要动态指定表名或列名的情况下。

选择使用哪个

#{} vs ${}
  • 安全性:在安全性方面,#{}更为安全,因为它会自动转义特殊字符,防止SQL注入攻击。
  • 性能:在性能方面,#{}优于${},因为预编译SQL可以减少数据库的解析负担。
  • 灵活性:在灵活性方面,${}比#{}更具优势,尤其是在需要动态生成SQL语句的部分(如表名、列名)。

使用场景示例

使用#{}的场景
  • 当你需要传递一个参数到SQL语句中,并且这个参数是一个具体的值时,比如idname等。
  • 当你关心SQL注入安全时。
使用${}的场景
  • 当你需要动态指定表名或列名时,比如根据用户的输入来决定查询哪个表。
  • 当你确信传入的参数是安全的,并且不需要进行SQL注入防护时。

总结

在大多数情况下,推荐使用#{}来传递参数,因为它提供了更好的安全性和性能。然而,在某些特定情况下,如需要动态生成表名或列名时, 可能是必要的选择。无论如何,使用 {}可能是必要的选择。无论如何,使用 可能是必要的选择。无论如何,使用{}时务必注意SQL注入的风险,并采取适当的安全措施。


http://www.ppmy.cn/embedded/107364.html

相关文章

打卡57天------图论(两种算法)

最近的算法题都太高深莫测了,对于一个前端工程师来说,要求没有那么严吧。 今天在学习prim 和 kruskal的同时,也要清楚这两个算法的区别所在。 一、prim算法精讲 代码随想录 无JS官方题解代码。 二、kruskal算法精讲 代码随想录 无JS官方题解…

Ubuntu22.04版本左右,开机自动启动脚本

Ubuntu22.04版本左右,开机自动启动脚本 1. 新增/lib/systemd/system/rc-local.service中[Install]内容 vim /lib/systemd/system/rc-local.service 按 i 进入插入模式后,新增内容如下: [Install] WantedBymulti-user.target Aliasrc-local.…

学生管理系统升级(登录注册 + 关联学生管理系统)

新增需求 这是在昨天的基础初代版本上面新增一个登录注册忘记密码的功能 需求分析 注册 登录 忘记密码 user类代码呈现 package StudentSystem;public class User {private String username;private String password;private String personID;private String phoneNumber;pu…

2024年装电脑,就认准这几个型号,能避坑!

前言 小伙伴是否都会觉得,自己又不懂电脑,跑电脑城去装机又怕被坑。这时候只能找熟人给装机,至少……熟人应该不会坑自己吧?! 这不,小白电脑技术的抖音评论区上就有这么一条评论: 这哥们找一熟…

制裁下的转型:俄罗斯加密货币战略布局与人民币挂钩BRICS稳定币的崛起

在国际制裁重压下,俄罗斯正在积极推进加密货币政策改革,通过设立加密货币交易所和推动与人民币挂钩的BRICS稳定币,试图在全球金融体系中谋求新的生存与发展路径。这一系列举措标志着俄罗斯在数字经济领域的重大转向,既是对当前经济…

2025第十二届广州国际汽车零部件加工技术及汽车模具展览会

2025第十二届广州国际汽车零部件加工技术及汽车模具展览会 时间:2025年11月20日-22日 地点:广州保利世贸博览馆 (PWTC Expo) 预计20000平方米展出面积;400多家参展商:20000多名观众; 汇集了各种汽车零部件成品、汽车…

零基础入门转录组数据分析——预后模型的验证

零基础入门转录组数据分析——预后模型的验证 目录 零基础入门转录组数据分析——预后模型的验证1. 预后模型的基础知识2. 预后模型的验证(Rstudio)——代码实操2. 1 数据处理2. 2 构建多因素cox模型(用输入的全部5个基因)2. 3 计…

【MySQL】初识MySQL—MySQL是啥,以及如何简单操作???

前言: 🌟🌟本期讲解关于MySQL的简单使用和注意事项,希望能帮到屏幕前的你。 🌈上期博客在这里:http://t.csdnimg.cn/wwaqe 🌈感兴趣的小伙伴看一看小编主页:GGBondlctrl-CSDN博客 目…