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

Mybatis的#{}和${}

#{}:预编译语句,用?对参数位置进行一个占位的操作,在数据库生成一个模版,等待后续填充.也可以推测出#在生成模版后的性能是比$快的.

${}:即时语句,提前的吧参数填充进去,在MySQL里就是一个完整的SQL语句.

填充逻辑不同
#{}会给String类型的参数自动的加上双引号,而${}则是直接填充.单着也给#带来了一些麻烦.比如在order by 的时候 的顺序desc和asc都是字符串,却不能加双引号,模糊查询的时候涉及到许多关键字的选择也是字符串这个时候也很麻烦.所以要选择性的用.

安全性

为什么说#比$安全呢,$相当于自己写一个SQL语句,而#则是MySQL给你一个模版,我们负责填值.值再花里胡哨那也和表的结构没啥关系.

相关文章:

  • 自适应SQL计划管理(Adaptive SQL Plan Management)在Oracle 12c中的应用
  • AD(Altium Designer)三种方法导入图片
  • 动态内存分配算法对比:最先适应、最优适应、最坏适应与邻近适应
  • 论文笔记-WSDM2025-ColdLLM
  • Hadoop-HA(高可用)机制
  • 重写QListWidget/QListView的代理,以网格的形式展示Item
  • jvm中各个参数的理解
  • Ubuntu编译ZLMediaKit
  • react实例与总结(二)
  • ollama修改监听ip: 0.0.0.0
  • deepseek清华大学第二版 如何获取 DeepSeek如何赋能职场应用 PDF文档 电子档(附下载)
  • 计算机网络基础杂谈(局域网、ip、子网掩码、网关、DNS)
  • 分布式 IO 模块:水力发电设备高效控制的关键
  • 正则表达式特殊字符
  • Nginx 常用命令和部署详解及案例示范
  • arthas教程(还没有全部写完,有空更新)
  • QT事件循环
  • 【Spring详解五】bean的加载
  • Debian软件包重构
  • 第三章:Transformer模型探索
  • 时代邻里:拟收购成都合达联行科技剩余20%股权
  • 财政部:前3月国有企业利润总额10907.4亿元,同比增1.7%
  • 马上评丨马拉松“方便门”被处罚,是一针清醒剂
  • 给印度立“人设”:万斯访印祭出美国关税战新招,但效果存疑
  • 全红婵、李宁亮相中国航天日论坛,体育和航天这一次紧密相连
  • 国际乒联祝贺王励勤当选中国乒协主席并向刘国梁致谢