当前位置: 首页 > news >正文

mybatis中#{}和${}的区别?

  • #{}是占位符,预编译处理;${}是拼接符,字符串替换,没有预编译处理。

  • Mybatis在处理#{}时,#{}传入参数是以字符串传入,会将SQL中的#{}替换为?号,调用PreparedStatement的set方法来赋值。

  • Mybatis在处理${}时 , 是原值传入 ,就是把{}时,是原值传入,就是把时,是原值传入,就是把{}替换成变量的值,相当于JDBC中的Statement编译

  • 变量替换后,#{} 对应的变量自动加上单引号 ‘’;变量替换后,${} 对应的变量不会加上单引号 ‘’

  • #{} 可以有效的防止SQL注入,提高系统安全性;${} 不能防止SQL 注入

  • #{} 的变量替换是在DBMS 中;${} 的变量替换是在 DBMS 外

http://www.lryc.cn/news/310953.html

相关文章:

  • 常用git 打tag命令
  • Learning from Unlabeled 3D Environments forVision-and-Language Navigation
  • 【算法分析与设计】组合
  • 数仓模型设计方法论
  • MySQL 面试题
  • 计算机专业必看的十部电影
  • 数据库之间数据迁移工具datax
  • uniapp:根据环境(开发、测试、生产)选择服务器接口或者业务
  • Leetcode—63. 不同路径 II【中等】
  • Redis 之三:Redis 的发布订阅(pub/sub)
  • ngx_waf入门教程:保护你的Nginx服务器
  • 视觉Transformers中的位置嵌入 - 研究与应用指南
  • 真香定律!我用这种模式重构了第三方登录
  • Linux入门到入土
  • 基础真空技术外国文献Fundamentals of Vacuum Technology
  • LeetCode每日一题【c++版】- 用队列实现栈与用栈实现队列
  • 深入理解快速排序算法:从原理到实现
  • 设计模式----装饰器模式
  • Golang pprof 分析程序的使用内存和执行时间
  • C/C++平方和问题(蓝桥杯)
  • (libusb) usb口自动刷新
  • NLP(一)——概述
  • 智慧公厕:打造智慧城市的环卫明珠
  • [LeetBook]【学习日记】寻找链表相交节点
  • 【Python】OpenCV-使用ResNet50进行图像分类
  • TypeError: `dumps_kwargs` keyword arguments are no longer supported
  • 设计模式学习笔记 - 设计原则 - 3.里氏替换原则,它和多态的区别是什么?
  • java实现图片转pdf,并通过流的方式进行下载(前后端分离)
  • 如何系统的学习Python——Python的基本语法
  • 相机,棱镜和光场