服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - 关于MyBatis模糊查询的几种实现方式

关于MyBatis模糊查询的几种实现方式

2023-05-02 14:08柚子猫屿 Java教程

在实际项目中,我们会经常对数据做一些模糊查询的操作,这时候就需要利用到 like字段,那么在Mybatis中,有哪些方式可以实现模糊查询呢,需要的朋友可以参考下

一、模糊查询的几种实现方式

1.concat函数和#{}拼接的方式

?
1
student_name like concat('%',#{studentName},'%')

2.%和${}拼接的方式

?
1
student_name like '%${studentName}%'

3.concat函数和${}拼接的方式

?
1
student_name like concat('%','${studentName}','%')

4.||和#{}拼接的方式

?
1
student_name like '%'||#{studentName}||'%'

分析: (1)${}:表示拼接sql串,将接收到参数的内容不加任何修饰拼接在sql中,可能引发sql注入。 (2)#{ }是预编译处理,MyBatis在处理#{ }时,它会将sql中的#{ }替换为?,然后调用PreparedStatement的set方法来赋值,传入字符串后,会在值两边加上单引号,使用占位符的方式提高效率,可以防止sql注入。因此最好使用#{ }方式。 (3)concat函数最好不要使用,最好使用||,因为在Oracle中,concat()只能对两个字符串进行拼接(字符串多的话只能嵌套使用),而||可以对字符串无限拼接。

5.建议使用的方式

建议使用第四种哦,示例:

?
1
2
3
<if test="studentName != null and studentName !=''">
    and student_name like '%'||#{studentName}||'%'
</if>

二、用mybatis出现的一些问题

1.一般查询条件的使用

在mapper文件里面关于查询if的条件基本都要写出两种空值,否则就会在查询时把其他不需要的数据也查出来。

错误示范:

?
1
2
3
<if test="studentName != null">
    and student_name = #{studentName}
</if>

正确示范:

?
1
2
3
<if test="studentName != null and studentName !=''">
    and student_name = #{studentName}
</if>

2.日期查询条件的使用

这个是在写日期查询条件时,出现了日期只能修改,但不能为空的问题:

错误示范:

?
1
2
3
4
5
6
<if test="effDate != null and effDate !=''">
    and eff_date = #{effDate}
</if>
<if test="expDate != null and expDate !=''">
    and exp_date = #{expDate}
</if>

正确示范:去掉外面的if判空条件

?
1
2
and eff_date = #{effDate}
and exp_date = #{expDate}

3.排序问题

查询时最好按id倒序,在修改之后不影响原有顺序

比如:order by student_id desc

到此这篇关于关于MyBatis模糊查询的几种实现方式的文章就介绍到这了,更多相关MyBatis模糊查询内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/qq_41861832/article/details/128243734

延伸 · 阅读

精彩推荐
  • Java教程Java枚举的七种常见用法总结(必看)

    Java枚举的七种常见用法总结(必看)

    下面小编就为大家带来一篇Java枚举的七种常见用法总结(必看)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    服务器之家3832020-07-01
  • Java教程IDEA 自动生成 JPA 实体类的图文教程

    IDEA 自动生成 JPA 实体类的图文教程

    这篇文章主要介绍了IDEA 自动生成 JPA 实体类的图文教程,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...

    「已注销」9902021-09-28
  • Java教程java基础学习笔记之泛型

    java基础学习笔记之泛型

    所谓泛型,就是变量类型的参数化。泛型是JDK1.5中一个最重要的特征。通过引入泛型,我们将获得编译时类型的安全和运行时更小的抛出ClassCastException的可...

    hebedich2012020-03-28
  • Java教程SpringBoot 入门教程之引入数据传输层的方法

    SpringBoot 入门教程之引入数据传输层的方法

    这篇文章主要介绍了SpringBoot 入门教程之引入数据传输层的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,...

    悟三空2792020-07-16
  • Java教程java中UDP简单聊天程序实例代码

    java中UDP简单聊天程序实例代码

    这篇文章主要介绍了java中UDP简单聊天程序实例代码,有需要的朋友可以参考一下 ...

    java技术网4102019-10-27
  • Java教程Java dom4j创建解析xml文档过程解析

    Java dom4j创建解析xml文档过程解析

    这篇文章主要介绍了Java dom4j创建解析xml文档过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以...

    黑仔0023462020-07-27
  • Java教程Java金额大小写的转换方法

    Java金额大小写的转换方法

    这篇文章主要为大家详细介绍了Java金额大小写的转换方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    欧阳鹏6522020-09-06
  • Java教程Spring Boot 自定义starter的示例代码

    Spring Boot 自定义starter的示例代码

    这篇文章主要介绍了Spring Boot 自定义starter的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    一花一四季,一梦一世界8152021-06-15