一线大厂面试真题-MyBatis中#{}和${}的区别是什么?

本文比较了MyBatis中#和$两种占位符在动态SQL中的使用,强调了#号占位符用于预编译防止SQL注入,而$号不提供此功能,适用于部分动态SQL场景。SQL注入问题仍需警惕。
摘要由CSDN通过智能技术生成

目录

问题解答

面试点评


问题解答

先,MyBatis提供到的#号占位符和$号占位符,都是实现动态SQL的一种方式,通过这两种方式把参数传递到XML之后,在执操作之前,MyBatis会对这两种占位符进行动态解析。

(图)#号占位符,等同于jdbc里面的?号占位符。

它相当于向PreparedStatement中的预处理语句中设置参数,而PreparedStatement中的sql语句是预编译的,SQL语句中使用了占位符,规定了sql语句的结构。

并且在设置参数的时候,如果有特殊字符,会自动进行转义。

所以#号占位符可以防止SQL注入。

(如图)而使用$的方式传参,相当于直接把参数拼接到了原始的SQL里面,MyBatis会对它进行特殊处理。

以$和#最大的区别在于,前者是动态参数,后者是占位符,动态参数无法防止SQL注入的问题,所以在实际应用中,应该尽可能的使用#号占位符。

另外,$符号的动态传参,可以适合应用在一些动态SQL场景中,比如动态传递表名、动态设置排序字段等。

面试点

一些小的细节如果不注意,就有可能造成巨大的经济损失。

比如现如今还是会有一些网站出现SQL注入导致信息泄露的问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值