Mybatis动态SQL语句查询,实现一个参数 可查询多个字段。

简介: Mybatis动态SQL语句查询,实现一个参数 可查询多个字段。

案例如下图所示:

eaa5cce937c8488eb66a3fafa02e99d4.png

实现 根据 登录名 姓名  邮箱  查询

一. 以下代码用  姓名 地址 模糊查询xml代码如下

<select id="queryClientList" resultType="com.lt.crm.vo.QueryClient.QueryDeliveryClientVo">
        select
        a.CUSTOMERSNO "customersno",
        a.CUSTOMERSNAME "customersname",
        a.COMMUNITY "community",
        a.CUSTOMERSTEL "customerstel"
        from CRM_CUSTOMERS a
        <where>
            <if test="integratedQuery != null and integratedQuery != ''">
                1=1 and a.customersname like concat(concat('%',#{integratedQuery}),'%') or  a.community like concat(concat('%',#{integratedQuery}),'%')
            </if>
            <if test="customersno != null and customersno != ''">
                and a.customersno like '%'||#{customersno}||'%'
            </if>
            <if test="customersname != null and customersname != ''">
                and a.customersname like '%'||#{customersname}||'%'
            </if>
            <if test="community != null and community != ''" >
                and a.community like '%'||#{community}||'%'
            </if>
        </where>
    </select>

二. 最重要的就是这一行:

<if test="integratedQuery != null and integratedQuery != ''">
       1=1 and a.customersname like concat(concat('%',#{integratedQuery}),'%') or  a.community like concat(concat('%',#{integratedQuery}),'%')
</if>

1. 动态sql中 where 1=1

1. where 1=1,因为它总是ture ,执行计划就会忽略这个条件,Oracle、MySQL 结果都一样。


2. 为了避免:条件A判断出错 或者 往条件A传值时,传了空值,导致sql报错。


3. where1=1不影响SQL性能,也不会导致索引失效。SQL优化器已经将where1=1过滤了。

2.解释:


1. a.customersname like concat(concat('%',#{integratedQuery}),'%')  这是查 名字


2. a.community like concat(concat('%',#{integratedQuery}),'%')           这是查 地址


3. 两个字段 写到 一个 if 里面   用关键函数 or 将 他们 关联


4. 定义一个 新的 字段 integratedQuery  这个字段是 前端给后端传值的字段  


5. 对应的dao service serviceImpl实现层  controller 都加上 (integratedQuery) 这个字段


integratedQuery  这个字段 也要在我们的实体类里 定义   我用的是VO 我就写Vo类里 如下:


b160aa84229f4ed38fc93c77fbda78e6.png


目录
相关文章
|
SQL Java 数据库连接
【YashanDB知识库】解决mybatis的mapper文件sql语句结尾加分号";"报错
【YashanDB知识库】解决mybatis的mapper文件sql语句结尾加分号";"报错
|
7月前
|
SQL XML Java
通过MyBatis的XML配置实现灵活的动态SQL查询
总结而言,通过MyBatis的XML配置实现灵活的动态SQL查询,可以让开发者以声明式的方式构建SQL语句,既保证了SQL操作的灵活性,又简化了代码的复杂度。这种方式可以显著提高数据库操作的效率和代码的可维护性。
461 18
|
11月前
|
SQL Java 数据库连接
MyBatis动态SQL字符串空值判断,这个细节99%的程序员都踩过坑!
本文深入探讨了MyBatis动态SQL中字符串参数判空的常见问题。通过具体案例分析,对比了`name != null and name != &#39;&#39;`与`name != null and name != &#39; &#39;`两种写法的差异,指出后者可能引发逻辑混乱。为避免此类问题,建议在后端对参数进行预处理(如trim去空格),简化MyBatis判断逻辑,提升代码健壮性与可维护性。细节决定成败,严谨处理参数判空是写出高质量代码的关键。
1522 0
|
SQL 索引
【YashanDB知识库】字段加上索引后,SQL查询不到结果
【YashanDB知识库】字段加上索引后,SQL查询不到结果
|
7月前
|
SQL Java 数据库连接
SSM相关问题-1--#{}和${}有什么区别吗?--Mybatis都有哪些动态sql?能简述一下动 态sql的执行原理吗?--Spring支持的几种bean的作用域 Scope
在MyBatis中,`#{}`是预处理占位符,可防止SQL注入,适用于大多数参数传递场景;而`${}`是直接字符串替换,不安全,仅用于动态表名、列名等特殊场景。二者在安全性、性能及使用场景上有显著区别。
280 0
|
10月前
|
SQL XML Java
菜鸟之路Day35一一Mybatis之XML映射与动态SQL
本文介绍了MyBatis框架中XML映射与动态SQL的使用方法,作者通过实例详细解析了XML映射文件的配置规范,包括namespace、id和resultType的设置。文章还对比了注解与XML映射的优缺点,强调复杂SQL更适合XML方式。在动态SQL部分,重点讲解了`&lt;if&gt;`、`&lt;where&gt;`、`&lt;set&gt;`、`&lt;foreach&gt;`等标签的应用场景,如条件查询、动态更新和批量删除,并通过代码示例展示了其灵活性与实用性。最后,通过`&lt;sql&gt;`和`&lt;include&gt;`实现代码复用,优化维护效率。
1021 5
|
SQL Java 数据库连接
【YashanDB 知识库】解决 mybatis 的 mapper 文件 sql 语句结尾加分号";"报错
【YashanDB 知识库】解决 mybatis 的 mapper 文件 sql 语句结尾加分号";"报错
|
SQL 缓存 Java
框架源码私享笔记(02)Mybatis核心框架原理 | 一条SQL透析核心组件功能特性
本文详细解构了MyBatis的工作机制,包括解析配置、创建连接、执行SQL、结果封装和关闭连接等步骤。文章还介绍了MyBatis的五大核心功能特性:支持动态SQL、缓存机制(一级和二级缓存)、插件扩展、延迟加载和SQL注解,帮助读者深入了解其高效灵活的设计理念。
|
SQL XML Java
九、MyBatis动态SQL
九、MyBatis动态SQL
224 2
|
SQL Java 数据库连接
如何在 Java 代码中使用 JSqlParser 解析复杂的 SQL 语句?
大家好,我是 V 哥。JSqlParser 是一个用于解析 SQL 语句的 Java 库,可将 SQL 解析为 Java 对象树,支持多种 SQL 类型(如 `SELECT`、`INSERT` 等)。它适用于 SQL 分析、修改、生成和验证等场景。通过 Maven 或 Gradle 安装后,可以方便地在 Java 代码中使用。
4435 11