在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默认值,可任意,且与参数无关 data:image/s3,"s3://crabby-images/39ee3/39ee3877f5ec665d94c7944f9d160b70f2ac2569" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/2c8b7/2c8b7a63e0557c8ea0ba5042a540d655fda223b9" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/fed87/fed877406eb4124d8fb29ed5284b8512e3263d29" alt="在这里插入图片描述"
${}
1、 使用Mybaits默认值value,即${value} data:image/s3,"s3://crabby-images/39ee3/39ee3877f5ec665d94c7944f9d160b70f2ac2569" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/16fc6/16fc697a8fcd13757bacb4edc5cbd66ce7a81ca0" alt="在这里插入图片描述"
2、使用自定义参数名,前提:在映射器接口方法的参数前加注解@Param("") data:image/s3,"s3://crabby-images/fb7e4/fb7e4b02c4222adb86118c4054a4ab669d5dc981" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/760fc/760fcd77d565c1f6619d69ca4fd87e01cad5ca26" alt="在这里插入图片描述"
多个参数的情形
#{}
1、使用Mybatis默认值arg0、arg1、arg2…或param1、param2、param3… data:image/s3,"s3://crabby-images/8593a/8593a160abfb5488fbe83ac8d4abe290591b1af8" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/b91fd/b91fddc072cf05f270e4c602a690ac00f5a87a44" alt="在这里插入图片描述"
2、 使用自定义参数名,前提: 在映射器接口方法的参数前加注解@Param("") data:image/s3,"s3://crabby-images/b04b8/b04b81bddb6eaac29f468798b7481b12fb66cf0e" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/81cbd/81cbdf1aa5afb23c3f03f8e74a3da785f6c3dafb" alt="在这里插入图片描述"
错误的使用的多个参数的情况
data:image/s3,"s3://crabby-images/1d806/1d80628337981109285b08ea890b887f58b5ab1a" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/33670/33670962bafa990dac3b4c5a3c50473d205672f8" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/79efd/79efd81abf99fefec9090523d7e3599ace181f7a" alt="在这里插入图片描述"
${}
1、使用Mybatis默认值arg0、arg1、arg2…或param1、param2、param3… data:image/s3,"s3://crabby-images/8593a/8593a160abfb5488fbe83ac8d4abe290591b1af8" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/29d29/29d294407b50f73ddd2a19cc8f1d06ad0265bdad" alt="在这里插入图片描述"
2、 使用自定义参数名,前提: 在映射器接口方法的参数前加注解@Param("") data:image/s3,"s3://crabby-images/b04b8/b04b81bddb6eaac29f468798b7481b12fb66cf0e" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/8620e/8620e860c4cbbb36ec90c05cf8e04a91ecc4dd3b" alt="在这里插入图片描述"
#{} 和 ${} 在使用中的技巧和建议
1、不论是单个参数,还是多个参数,一律都建议使用注解@Param("") 2、 能用 #{} 的地方就用 #{},不用或少用${} 3、表名作参数时,必须用${} 。如:select * from ${tableName} 4、order by 时,必须用 ${} 。如:select * from t_user order by ${columnName} 5、表名处用#{}会直接报错;order by后面用#{}排序不生效 6、使用 ${} 时,要注意何时加或不加单引号,即${} 和 '${}' 。一般字段类型为char或者varchar时需要加单引号
|