IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> MyBatis中#{}和${}的区别 -> 正文阅读

[大数据]MyBatis中#{}和${}的区别


在MyBatis 的映射配置文件中,动态传递参数有两种方式:
1、 #{} 占位符
2、 ${} 拼接符

#{} 和 ${} 的区别

区别1

  • #{} 为参数占位符 ?,即sql 预编译
  • ${} 为字符串替换,即 sql 拼接

区别2、

  • #{}:动态解析 -> 预编译 -> 执行
  • ${}:动态解析 -> 编译 -> 执行

区别 3、

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

区别 4、

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

区别 5、

  • #{} 能防止sql 注入
  • ${} 不能防止sql 注入

#{} 和 ${} 的实例:假设传入参数为 1

实例步骤一

#{}:select * from t_user where uid=#{uid}

${}:select * from t_user where uid= '${uid}'

实例步骤二

#{}:select * from t_user where uid= ?

${}:select * from t_user where uid= '1'

实例步骤三

#{}:select * from t_user where uid= '1'

${}:select * from t_user where uid= '1'

#{} 和 ${} 的大括号中的值

单个参数的情形

#{}

无Mybaits默认值,可任意,且与参数无关
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

${}

1、 使用Mybaits默认值value,即${value}
在这里插入图片描述在这里插入图片描述

2、使用自定义参数名,前提:在映射器接口方法的参数前加注解@Param("")
在这里插入图片描述
在这里插入图片描述

多个参数的情形

#{}

1、使用Mybatis默认值arg0、arg1、arg2…或param1、param2、param3…
在这里插入图片描述
在这里插入图片描述

2、 使用自定义参数名,前提: 在映射器接口方法的参数前加注解@Param("")
在这里插入图片描述
在这里插入图片描述

错误的使用的多个参数的情况

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

${}

1、使用Mybatis默认值arg0、arg1、arg2…或param1、param2、param3…
在这里插入图片描述
在这里插入图片描述

2、 使用自定义参数名,前提: 在映射器接口方法的参数前加注解@Param("")
在这里插入图片描述
在这里插入图片描述

#{} 和 ${} 在使用中的技巧和建议

1、不论是单个参数,还是多个参数,一律都建议使用注解@Param("")
2、 能用 #{} 的地方就用 #{},不用或少用${}
3、表名作参数时,必须用${}。如:select * from ${tableName}
4、order by 时,必须用 ${}。如:select * from t_user order by ${columnName}
5、表名处用#{}会直接报错;order by后面用#{}排序不生效
6、使用 ${} 时,要注意何时加或不加单引号,即${} 和 '${}'。一般字段类型为char或者varchar时需要加单引号

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-12-10 11:07:42  更:2021-12-10 11:07:55 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 10:25:40-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码