首页 > 其他分享 >mybatis中#{}和${}的区别

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

时间:2024-08-19 11:57:46浏览次数:6  
标签:name 传入 区别 order sql mybatis 解析 id

mybatis中#{}和${}的区别
  1. #将传入的数据都当成一个字符串,会对自动传入的数据加一个双引号。如:order by #user_id#,如果传入的值是111,那么解析成sql时的值为order by “111”, 如果传入的值是id,则解析成的sql为order by “id”.

  2. $将传入的数据直接显示生成在sql中。如:order by u s e r i d user_id useri​d,如果传入的值是111,那么解析成sql时的值为order by user_id, 如果传入的值是id,则解析成的sql为order by id.

  3. #方式能够很大程度防止sql注入。

    4.$方式无法防止Sql注入。

    5.KaTeX parse error: Expected 'EOF', got '#' at position 32: …传入表名.    6.一般能用#̲的就别用.

MyBatis排序时使用order by 动态参数时需要注意,用$而不是#

字符串替换
默认情况下,使用#{}格式的语法会导致MyBatis创建预处理语句属性并以它为背景设置安全的值(比如?)。这样做很安全,很迅速也是首选做法,有时你只是想直接在SQL语句中插入一个不改变的字符串。比如,像ORDER BY,你可以这样来使用:
ORDER BY ${columnName}
这里MyBatis不会修改或转义字符串。

重要:接受从用户输出的内容并提供给语句中不变的字符串,这样做是不安全的。这会导致潜在的SQL注入攻击,因此你不应该允许用户输入这些字段,或者通常自行转义并检查。

理解二

我觉得#与KaTeX parse error: Expected 'EOF', got '#' at position 9: 的区别最大在于:#̲{} 传入值时,sql解析时,…{}传入值,sql解析时,参数是不带引号的。

一 : 理解mybatis中 $与#

在mybatis中的$与#都是在sql中动态的传入参数。

eg:select id,name,age from student where name=#{name} 这个name是动态的,可变的。当你传入什么样的值,就会根据你传入的值执行sql语句。

二:使用$与#

#{}: 解析为一个 JDBC 预编译语句(prepared statement)的参数标记符,一个 #{ } 被解析为一个参数占位符 。

${}: 仅仅为一个纯碎的 string 替换,在动态 SQL 解析阶段将会进行变量替换。

name–>cy

eg: select id,name,age from student where name=#{name} – name=‘cy’

​ select id,name,age from student where name=${name} – name=cy

sql语句中#{}表示一个占位符。

标签:name,传入,区别,order,sql,mybatis,解析,id
From: https://blog.csdn.net/weixin_59335007/article/details/141263373

相关文章

  • 在K8S中,Deployment⽀持扩容吗?它与HPA有什么区别?
    在Kubernetes(K8S)中,Deployment支持扩容,并且是用于管理应用的推荐方式之一。Deployment提供了一种声明式的方式来更新应用实例,并支持滚动更新、回滚等功能。下面详细介绍Deployment的扩容功能及其与HorizontalPodAutoscaler(HPA)的区别。1.Deployment的扩容功能在......
  • Mybatis-Plus中的@TableName 和 table-prefix
    简介本文介绍Mybatis-Plus中的@TableName和table-prefix的使用。介绍在MyBatis-Plus中,@TableName注解和table-prefix配置都可以用来指定表名,但它们的作用方式略有不同。table-prefix配置table-prefix是一个全局配置,它会自动在所有表名前添加指定的前缀,这个配置对于......
  • Unity 中 Color 与 Color32 的区别
    1.存储方式Color用四个浮点数(float)来表示RGBA,取值范围均是0到1举例:varorange=newColor(1f,0.5f,0f,1f);而Color32使用四个字节(byte)表示RGBA,取值范围是0到255举例:varorange=newColor32(255,128,0,255);2.区别由存储方式可以看出,Color32采用字节存储,占......
  • 总结指针数组与数组指针的区别
    1、指针数组1-1、定义指针数组是一个数组,其元素是指针。这意味着数组的每个位置都存储了一个指针,这些指针可以指向任何类型的数据(包括其他数组、结构体等)。1-2、类型如果有一个指向整数的指针数组,其类型可能是 int*arr[N];,这里 arr 是一个数组,包含 N 个 int* 类型......
  • ASCII和Unicode区别
    ASCII和Unicode的主要区别在于它们的编码范围、长度、兼容性、支持的语言种类以及编码方式。‌编码范围和长度‌:ASCII编码只能表示128个字符,包括英文字母、数字和一些标点符号,每个字符占用一个字节。而Unicode编码可以表示几乎所有语言的字符,包括拉丁文、中文、日文等,每个......
  • 030、Vue3+TypeScript基础,路由中History和HashHistory的区别
    01、index.ts路由代码如下://创建路由并暴露出去import{createRouter,createWebHistory}from'vue-router'importHomefrom'@/view/Home.vue'importAboutfrom'@/view/About.vue'importNewsfrom'@/view/News.vue'constrouter=cr......
  • 麦当劳和肯德基的区别是什么,带大家了解
    一提起快餐,大家脑海中首先浮现的往往是那两个金字招牌——麦当劳和肯德基。它们如同快餐界的双子星,各自闪耀,却又总是被人拿来比较。今天,富贵我就带大家深入剖析一下,麦当劳和肯德基这两大快餐巨头到底有哪些区别,让你在下次选择时不再纠结!一、品牌起源与历史麦当劳和肯......
  • char 和varchar 区别与用法以及效率
    char(固定长度字符)定义:CHAR(n)表示一个固定长度的字符字段,n是字符的长度。即使实际存储的数据短于n,也会自动用空格填充到指定长度。存储方式:因为长度固定,所以每个CHAR(n)字段都占用n个字节,不论实际存储的数据长度如何。效率:读取效率:在处理固定长度的数据时,CHAR通常会......
  • Mybatis学习日记-day7-动态sql
    一、学习目标        在之前的学习中,使用的都是静态sql,而动态SQL相比静态SQL具有多个显著的优点。    首先。,动态SQL允许根据程序运行时的条件和需求来动态地生成SQL语句。这意味着它可以根据不同的情境和需求生成不同的SQL语句,从而提供更高的灵活性和适应......
  • String和StringBuilder的区别
    //创建一个控制台应用程序,在Mian()方法中编写如下代码,验证字符串操作和可变字符串操作的执行效率。stringstr="";longlongStartTime=DateTime.Now.Millisecond;for(inti=0;i<10000;i++){......