大家都知道bind标签可以使用OGNL表达式创建一个变量井将其绑定到上下文中,接下来通过本文给大家介绍了mybatis模糊查询——bind标签和concat函数用法,需要的朋友可以参考下
1.二种方式都可以用来模糊查询,都能预防 SQL 注入。但是在更换数据库情况下,bind标签通用。
<if test=” userName != null and userName !=””>
and userName like concat('%' ,#{userName},'%')
</if>
2.使用concat函数连接字符串,在mysql中这个函数支持多个参数,但是在oracle中这个函数只支持2个参数,由于不同数据库之间的语法差异,更换数据库,这些语法就需要重写。可以用bind标签来避免更换数据库所带来的一些麻烦。
eg.MyBatis在Oracle数据库下用concat函数模糊查询之参数个数无效错误,因为数据库换成了Oracle,在模糊查询数据的时候突然发现报错了
select * from SYS_MENU where url like concat('%',#{roleName},'%')
实际上oracle中不支持concat的三个参数的拼接,需要更正为
select * from SYS_MENU where url like concat(concat('%',#{roleName}),'%')
或者使用
select * from SYS_MENU where url like '%' || #{roleName} || '%';
bind标签使用:
bind 标签可以使用 OGNL 表达式创建一个变量井将其绑定到上下文中。
<bind name= " userNameBind ” value = ”' % '+ userNarne + ' %'” />
<if test=” userName != null and userName !=””>
and userName like #{userNameBind}
</if>
bind 标签的两个属性都是必选项
name 为绑定到上下文的变量名, value 为 OGNL 表达式。
创建一个 bind标签的变量后 , 就可以在下面直接使用,使用 bind 拼接字符串不仅可以避免因更换数据库而修改 SQL,也能预防 SQL注入,还能实现多个引用userNameBind
到此这篇关于mybatis模糊查询之bind标签和concat函数用法的文章就介绍到这了,更多相关mybatis模糊查询内容请搜索编程学习网以前的文章希望大家以后多多支持编程学习网!
本文标题为:mybatis模糊查询之bind标签和concat函数用法详解
- 如何使用WebFilter实现授权头检查 2022-01-01
- Java包名称中单词分隔符的约定是什么? 2022-01-01
- Eclipse 插件更新错误日志在哪里? 2022-01-01
- C++ 和 Java 进程之间的共享内存 2022-01-01
- Jersey REST 客户端:发布多部分数据 2022-01-01
- value & 是什么意思?0xff 在 Java 中做什么? 2022-01-01
- 将log4j 1.2配置转换为log4j 2配置 2022-01-01
- Safepoint+stats 日志,输出 JDK12 中没有 vmop 操作 2022-01-01
- 从 finally 块返回时 Java 的奇怪行为 2022-01-01
- Spring Boot连接到使用仲裁器运行的MongoDB副本集 2022-01-01