两者都可以在mybatis中用在输入映射

  1. #{}是预编译处理,
  2. ${}是字符串替换。
  • mybatis在处理#{}时,会将sql中的#{}替换为?号,调用PreparedStatement的set方法来赋值;
  • mybatis在处理 $ { } 时,就是把 ${ } 替换成变量的值,完成的是简单的字符串拼接。

补充:在mybatis中使用#{}可以防止sql注入,提高系统安全性

在大多数情况下,我们都是采用#{}读取参数内容.但是在一些特殊的情况下,我们还是需要使用${}读取参数的.

比如 有两张表,分别是emp_2017 和 emp_2018 .如果需要在查询语句中动态指定表名,就只能使用KaTeX parse error: Expected group after ‘_’ at position 37: …ect * from emp_̲{year}
再比如.需要动态的指定查询中的排序字段,此时也只能使用${}

select * from dept order by ${name}

简单来说,在JDBC不支持使用占位符的地方,都可以使用${}

${}和#{}的区别相关推荐

  1. RPC 笔记(01)— RPC概念、调用流程、RPC 与 Restful API 区别

    1. 基本概念 PRC 远程过程调用 Remote Procedure Call,其就是一个节点请求另外一个节点提供的服务.当两个物理分离的子系统需要建立逻辑上的关联时,RPC 是牵线搭桥的常见技术手 ...

  2. C++ 笔记(28)— C++ 中 NULL和 nullptr 的区别

    最近看公司代码的时候发现在判断指针是否为空的时候,有的时候用的是 NULL, 有的时候用的是 nullptr 感觉很奇怪,好奇心驱使我查了下两者的区别,发现还是有很多细节需要学习的. 1. NULL ...

  3. gcc 和 g++ 的联系和区别,使用 gcc 编译 c++

    GCC 编译器已经为我们提供了调用它的接口,对于 C 语言或者 C++ 程序,可以通过执行 gcc 或者 g++ 指令来调用 GCC 编译器. 实际使用中我们更习惯使用 gcc 指令编译 C 语言程序 ...

  4. Python2 与 Python3 区别

    Python2.x 与 Python3.x 区别 1. print 函数 Python2 中 print 是语句(statement),Python3 中 print 则变成了函数.在 Python3 ...

  5. Docker 入门系列(1)- 初识容器,镜像、容器、仓库的区别

    Docker 简介 Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从Apache2.0协议开源. Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发 ...

  6. HTTP 协议入门 — (TCP/IP协议族、通信传输流、URI 与 URL 的区别、Cookie 状态管理、HTTP 支持的方法、状态码类别、HTTP 首部字段)

    TCP/IP协议族 在介绍 HTTP 协议之前,我们先对 TCP/IP 协议族有个大概的了解,TCP/IP 协议从上到下主要分为应用层.传输层.网络层和数据链路层,各层的主要功能如下表所示: 协议层 ...

  7. python二进制打开(rb)和文本格式打开(r)什么区别?

    使用 open() 函数以文本格式打开文件和以二进制格式打开文件,唯一的区别是对文件中换行符的处理不同. 在 Windows 系统中,文件中用 "\r\n" 作为行末标识符(即换行 ...

  8. python中__dict__与dir()区别

    前言 Python下一切皆对象,每个对象都有多个属性(attribute),Python对属性有一套统一的管理方案. __dict__与dir()的区别: dir()是一个函数,返回的是list: _ ...

  9. java和C#面向对象的区别

    问题:C#中的构造函数和java的构造函数一样吗? 答: .net的项目中,写实体Entity属性时,经常会为每一个属性写一对get和set方法,在用到这个实体或是一个类时,通过new实例化一个对象, ...

  10. 判别模型和生成模型的区别

    20210703 https://www.zhihu.com/question/20446337 机器学习"判定模型"和"生成模型"有什么区别? 重点 http ...

最新文章

  1. emc celerra(一)--界面概览
  2. ios 从assets加载图片_Flutter图片添加水印功能,Flutter保存Widget为图片
  3. 类的公有类型(public)和私有类型(private)
  4. html5的文档申明为什么是!DOCTYPE html?
  5. java switch finally_JavaSE
  6. PAT-甲级之树遍历问题的总结
  7. Oracle Rownum 伪列详解
  8. ADO.NET Entity Framework 学习(1)
  9. SQL Server 批量插入数据的两种方法 - 转
  10. 【简单思考】noip模拟赛 NTR酋长
  11. access数据库指定日期查询
  12. 文件删不掉需要管理员权限?分享解决方法
  13. 基于内容的垃圾邮件过滤
  14. 男人养肾按摩运动更可取
  15. GOlang将华氏温度转换为摄氏温度的函数
  16. java muti实现图片上传_使用MultipartFile实现文件上传
  17. 产量预测文献读后整理
  18. 搭建自己的BT下载平台服务器
  19. 什么是国际物流专线?国际快递专线又是什么呢?
  20. Mac OS命令行清洗硬盘空间

热门文章

  1. linux压缩与解压缩命令
  2. 程序设计实习MOOC / 程序设计与算法(三)第一周测验
  3. 手机端设置https访问代理(windows)
  4. C++用法的学习心得
  5. CentOS 6.5 安装与配置LAMP
  6. ORA-01092: ORACLE 例程终止 强行断开连接
  7. 5月份升级鸿蒙系统的华为手机名单,鸿蒙OS前三批升级名单曝光,华为荣耀手机可升级,幸福来得太突然...
  8. C++编译链接的那些小事
  9. 2020教资高频考点作文素材汇总
  10. USTC English Club Note20171021