Mybatis ${} 和#{} 的区别

本文详细介绍了Mybatis中#{param}

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在Mybatis中,Mapper.xml文件中引用传入的参数是通过${param}或者#{param}来实现的。所以需要注意两者之间的区别
在这里插入图片描述

基本对比
#{ }:

  1. 会进行预编译 会进行类型匹配
  2. 用于变量替换

${ }:

  1. 不进行数据类型匹配
  2. 实质上是字符串拼接.

两者使用场景

  1. 变量传递必须使用# ,#{}相当于使用PrepareStatement这种占位符的形式,提高效率,防止sql注入,该方式一般用于传入添加、修改的值或者查询等。
  2. $ 就是简单的字符串拼接,有sql注入的风险。对于非变量部分,只能使用$,一般用于传入数据库对象,比如表名、字段名、等没法使用占位符的。
  3. 对于两者均可使用的位置,优先使用#
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Mr小布懂

谢谢那么帅还对我这么好

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值