mybatis中的#和$的区别是什么
发表于:2025-02-05 作者:千家信息网编辑
千家信息网最后更新 2025年02月05日,这篇文章主要介绍"mybatis中的#和$的区别是什么",在日常操作中,相信很多人在mybatis中的#和$的区别是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"m
千家信息网最后更新 2025年02月05日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安全错误
数据库的锁怎样保障安全
刺猬猫阅读服务器
JAVA通信软件开发工程师
江苏net软件开发正规平台
软件开发行业的利润
vb2010读取数据库表
马鞍山网络技术研发公司
互联网科技张群华
云服务器企业软件服务
2019年福彩3d开奖数据库
网络安全的认证方式有哪些
电脑访问服务器速度慢
扬州服务器规格
软件开发外包公司多吗
河北安卓软件开发哪家好
维护两千人的服务器很费钱吗
青少年网络安全的海报
.net 备份数据库
丽水政务软件开发多少钱
如何在数据库中快速提取数据
服务器故障原因是什么
系统定制储物柜软件开发
医院职工网络安全
网络安全法 新秩序
软件开发哪一款笔记本好
服务器上能不能配置几个raid
网络安全攻防实训平台价格
奉贤区多层软件开发设备
东莞软件开发驻场代理公司
郑州 直销软件开发公司排名
天津中力电气软件开发