mybatis中的#和$的区别是什么
发表于:2025-12-04 作者:千家信息网编辑
千家信息网最后更新 2025年12月04日,这篇文章主要介绍"mybatis中的#和$的区别是什么",在日常操作中,相信很多人在mybatis中的#和$的区别是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"m
千家信息网最后更新 2025年12月04日mybatis中的#和$的区别是什么
这篇文章主要介绍"mybatis中的#和$的区别是什么",在日常操作中,相信很多人在mybatis中的#和$的区别是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"mybatis中的#和$的区别是什么"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
问题详情
在我们拼接mysql的语句时, 通常会有大佬提醒我们,要注意 #和$符号的使用:
id = #{id} , id = ${id} , 那这两种写法有什么区别呢?
问题解答
用#号的号,可以用使用PreparedStatement+占位符的方式来拼sql语句,可以防止sql注入,更安全
问题解析
对#号的处理
源码中,对#{}的特殊处理可以在这个位置看到

然后我们断点打开解析器里面,可以看到在解析完之后,就从#{id} 变成了 ?

在换成?的同时,把id包装成parameterMapping并添加到parameterMappings中,后面还要获取出来,然后拿值,再把值放到prepareStatement中
一步步debug下来,我们经过了 Executor(执行器) , 然后到TypeHandler, 找到对应的参数处理器,然后执行 ps.setInt('位置','值'). 完成了整个过程
对$号的处理
这个就很简单了
在调用SqlSource.getBoundSql() 去获取要执行sql的时候,就会被token解析器给换成值了.
到此,关于"mybatis中的#和$的区别是什么"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!
问题
处理
学习
位置
更多
语句
帮助
解答
实用
特殊
安全
接下来
写法
参数
同时
处理器
常会
文章
断点
方式
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全框架CSF包括哪些
池州网络安全考试公司
服务器开发进阶
上半年经济数据库笔记
软件开发人员的薪金 论文
港股互联网科技基金
软件开发基准人月费
系统集成和软件开发哪个好
计算机网络技术的产生背景
形成网络安全思想
海康威视服务器管理ip
中国知网的数据库的域名
电脑设置dhcp服务器
oracle数据库入库慢
网络安全网络培训心得
r420服务器尺寸多少合适
劳务派遣网络安全管理岗位
全球网络安全高峰论坛
计算独立用户的数据库推荐
网络安全宣传进家庭
福建省网络安全比赛
阿里云数据库表恢复吗
云服务器可以玩暗黑破坏神3吗
orcal数据库增删改
服务器上有多少内存条
商贸零售erp软件开发
用友t材料数据库在哪
服务器限制电脑ip段
软件开发哪一步最难
数据库的名字含义