${}和#{}的区别
两者都可以在mybatis中用在输入映射
- #{}是预编译处理,
- ${}是字符串替换。
- 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不支持使用占位符的地方,都可以使用${}
${}和#{}的区别相关推荐
- RPC 笔记(01)— RPC概念、调用流程、RPC 与 Restful API 区别
1. 基本概念 PRC 远程过程调用 Remote Procedure Call,其就是一个节点请求另外一个节点提供的服务.当两个物理分离的子系统需要建立逻辑上的关联时,RPC 是牵线搭桥的常见技术手 ...
- C++ 笔记(28)— C++ 中 NULL和 nullptr 的区别
最近看公司代码的时候发现在判断指针是否为空的时候,有的时候用的是 NULL, 有的时候用的是 nullptr 感觉很奇怪,好奇心驱使我查了下两者的区别,发现还是有很多细节需要学习的. 1. NULL ...
- gcc 和 g++ 的联系和区别,使用 gcc 编译 c++
GCC 编译器已经为我们提供了调用它的接口,对于 C 语言或者 C++ 程序,可以通过执行 gcc 或者 g++ 指令来调用 GCC 编译器. 实际使用中我们更习惯使用 gcc 指令编译 C 语言程序 ...
- Python2 与 Python3 区别
Python2.x 与 Python3.x 区别 1. print 函数 Python2 中 print 是语句(statement),Python3 中 print 则变成了函数.在 Python3 ...
- Docker 入门系列(1)- 初识容器,镜像、容器、仓库的区别
Docker 简介 Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从Apache2.0协议开源. Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发 ...
- HTTP 协议入门 — (TCP/IP协议族、通信传输流、URI 与 URL 的区别、Cookie 状态管理、HTTP 支持的方法、状态码类别、HTTP 首部字段)
TCP/IP协议族 在介绍 HTTP 协议之前,我们先对 TCP/IP 协议族有个大概的了解,TCP/IP 协议从上到下主要分为应用层.传输层.网络层和数据链路层,各层的主要功能如下表所示: 协议层 ...
- python二进制打开(rb)和文本格式打开(r)什么区别?
使用 open() 函数以文本格式打开文件和以二进制格式打开文件,唯一的区别是对文件中换行符的处理不同. 在 Windows 系统中,文件中用 "\r\n" 作为行末标识符(即换行 ...
- python中__dict__与dir()区别
前言 Python下一切皆对象,每个对象都有多个属性(attribute),Python对属性有一套统一的管理方案. __dict__与dir()的区别: dir()是一个函数,返回的是list: _ ...
- java和C#面向对象的区别
问题:C#中的构造函数和java的构造函数一样吗? 答: .net的项目中,写实体Entity属性时,经常会为每一个属性写一对get和set方法,在用到这个实体或是一个类时,通过new实例化一个对象, ...
- 判别模型和生成模型的区别
20210703 https://www.zhihu.com/question/20446337 机器学习"判定模型"和"生成模型"有什么区别? 重点 http ...
最新文章
- emc celerra(一)--界面概览
- ios 从assets加载图片_Flutter图片添加水印功能,Flutter保存Widget为图片
- 类的公有类型(public)和私有类型(private)
- html5的文档申明为什么是!DOCTYPE html?
- java switch finally_JavaSE
- PAT-甲级之树遍历问题的总结
- Oracle Rownum 伪列详解
- ADO.NET Entity Framework 学习(1)
- SQL Server 批量插入数据的两种方法 - 转
- 【简单思考】noip模拟赛 NTR酋长
- access数据库指定日期查询
- 文件删不掉需要管理员权限?分享解决方法
- 基于内容的垃圾邮件过滤
- 男人养肾按摩运动更可取
- GOlang将华氏温度转换为摄氏温度的函数
- java muti实现图片上传_使用MultipartFile实现文件上传
- 产量预测文献读后整理
- 搭建自己的BT下载平台服务器
- 什么是国际物流专线?国际快递专线又是什么呢?
- Mac OS命令行清洗硬盘空间
热门文章
- linux压缩与解压缩命令
- 程序设计实习MOOC / 程序设计与算法(三)第一周测验
- 手机端设置https访问代理(windows)
- C++用法的学习心得
- CentOS 6.5 安装与配置LAMP
- ORA-01092: ORACLE 例程终止 强行断开连接
- 5月份升级鸿蒙系统的华为手机名单,鸿蒙OS前三批升级名单曝光,华为荣耀手机可升级,幸福来得太突然...
- C++编译链接的那些小事
- 2020教资高频考点作文素材汇总
- USTC English Club Note20171021