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


目录
相关文章
|
3月前
|
SQL XML Java
通过MyBatis的XML配置实现灵活的动态SQL查询
总结而言,通过MyBatis的XML配置实现灵活的动态SQL查询,可以让开发者以声明式的方式构建SQL语句,既保证了SQL操作的灵活性,又简化了代码的复杂度。这种方式可以显著提高数据库操作的效率和代码的可维护性。
246 18
|
8月前
|
SQL Java 数据库连接
【YashanDB知识库】解决mybatis的mapper文件sql语句结尾加分号";"报错
【YashanDB知识库】解决mybatis的mapper文件sql语句结尾加分号";"报错
|
7月前
|
SQL Java 数据库连接
MyBatis动态SQL字符串空值判断,这个细节99%的程序员都踩过坑!
本文深入探讨了MyBatis动态SQL中字符串参数判空的常见问题。通过具体案例分析,对比了`name != null and name != &#39;&#39;`与`name != null and name != &#39; &#39;`两种写法的差异,指出后者可能引发逻辑混乱。为避免此类问题,建议在后端对参数进行预处理(如trim去空格),简化MyBatis判断逻辑,提升代码健壮性与可维护性。细节决定成败,严谨处理参数判空是写出高质量代码的关键。
926 0
|
4月前
|
SQL XML Java
MyBatis Mapper中使用limit参数的查询问题
总结而言,MyBatis中使用 `limit`参数的查询可以高度定制并且灵活,基于方法签名和XML映射文件的组合来达成多样化的查询需求。通过参数化查询和动态SQL,MyBatis可以有效地处理各种复杂情境下的数据库操作,并且将SQL语句的维护与业务代码的编写相分离,提升代码的可维护性和可阅读性。
418 13
|
3月前
|
SQL Java 数据库连接
SSM相关问题-1--#{}和${}有什么区别吗?--Mybatis都有哪些动态sql?能简述一下动 态sql的执行原理吗?--Spring支持的几种bean的作用域 Scope
在MyBatis中,`#{}`是预处理占位符,可防止SQL注入,适用于大多数参数传递场景;而`${}`是直接字符串替换,不安全,仅用于动态表名、列名等特殊场景。二者在安全性、性能及使用场景上有显著区别。
77 0
|
8月前
|
SQL 索引
【YashanDB知识库】字段加上索引后,SQL查询不到结果
【YashanDB知识库】字段加上索引后,SQL查询不到结果
|
6月前
|
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;`实现代码复用,优化维护效率。
523 5
|
8月前
|
SQL Java 数据库连接
【YashanDB 知识库】解决 mybatis 的 mapper 文件 sql 语句结尾加分号";"报错
【YashanDB 知识库】解决 mybatis 的 mapper 文件 sql 语句结尾加分号";"报错
|
8月前
|
SQL 缓存 Java
框架源码私享笔记(02)Mybatis核心框架原理 | 一条SQL透析核心组件功能特性
本文详细解构了MyBatis的工作机制,包括解析配置、创建连接、执行SQL、结果封装和关闭连接等步骤。文章还介绍了MyBatis的五大核心功能特性:支持动态SQL、缓存机制(一级和二级缓存)、插件扩展、延迟加载和SQL注解,帮助读者深入了解其高效灵活的设计理念。
|
8月前
|
SQL XML Java
四、MyBatis获取参数值的两种方式(重点)
四、MyBatis获取参数值的两种方式(重点)
149 4