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


目录
相关文章
|
4月前
|
SQL 监控 关系型数据库
一键开启百倍加速!RDS DuckDB 黑科技让SQL查询速度最高提升200倍
RDS MySQL DuckDB分析实例结合事务处理与实时分析能力,显著提升SQL查询性能,最高可达200倍,兼容MySQL语法,无需额外学习成本。
|
4月前
|
SQL 存储 关系型数据库
MySQL体系结构详解:一条SQL查询的旅程
本文深入解析MySQL内部架构,从SQL查询的执行流程到性能优化技巧,涵盖连接建立、查询处理、执行阶段及存储引擎工作机制,帮助开发者理解MySQL运行原理并提升数据库性能。
|
4月前
|
SQL 监控 关系型数据库
SQL优化技巧:让MySQL查询快人一步
本文深入解析了MySQL查询优化的核心技巧,涵盖索引设计、查询重写、分页优化、批量操作、数据类型优化及性能监控等方面,帮助开发者显著提升数据库性能,解决慢查询问题,适用于高并发与大数据场景。
|
5月前
|
SQL XML Java
通过MyBatis的XML配置实现灵活的动态SQL查询
总结而言,通过MyBatis的XML配置实现灵活的动态SQL查询,可以让开发者以声明式的方式构建SQL语句,既保证了SQL操作的灵活性,又简化了代码的复杂度。这种方式可以显著提高数据库操作的效率和代码的可维护性。
341 18
|
3月前
|
SQL 关系型数据库 MySQL
(SQL)SQL语言中的查询语句整理
查询语句在sql中占了挺大一部分篇幅,因为在数据库中使用查询语句的次数远多于更新与删除命令。而查询语句比起其他语句要更加的复杂,可因为sql是数据库不可或缺的一部分,所以即使不懂,也必须得弄懂,以上。
264 0
|
6月前
|
SQL XML Java
MyBatis Mapper中使用limit参数的查询问题
总结而言,MyBatis中使用 `limit`参数的查询可以高度定制并且灵活,基于方法签名和XML映射文件的组合来达成多样化的查询需求。通过参数化查询和动态SQL,MyBatis可以有效地处理各种复杂情境下的数据库操作,并且将SQL语句的维护与业务代码的编写相分离,提升代码的可维护性和可阅读性。
555 13
|
5月前
|
SQL 人工智能 数据库
【三桥君】如何正确使用SQL查询语句:避免常见错误?
三桥君解析了SQL查询中的常见错误和正确用法。AI产品专家三桥君通过三个典型案例:1)属性重复比较错误,应使用IN而非AND;2)WHERE子句中非法使用聚合函数的错误,应改用HAVING;3)正确的分组查询示例。三桥君还介绍了学生、课程和选课三个关系模式,并分析了SQL查询中的属性比较、聚合函数使用和分组查询等关键概念。最后通过实战练习帮助读者巩固知识,强调掌握这些技巧对提升数据库查询效率的重要性。
187 0
|
6月前
|
SQL
SQL中如何删除指定查询出来的数据
SQL中如何删除指定查询出来的数据
|
7月前
|
SQL Java 数据库
解决Java Spring Boot应用中MyBatis-Plus查询问题的策略。
保持技能更新是侦探的重要素质。定期回顾最佳实践和新技术。比如,定期查看MyBatis-Plus的更新和社区的最佳做法,这样才能不断提升查询效率和性能。
302 1
|
7月前
|
SQL 存储 弹性计算
OSS Select 加速查询:10GB CSV 文件秒级过滤的 SQL 语法优化技巧
OSS Select 可直接在对象存储上执行 SQL 过滤,跳过文件下载,仅返回所需数据,性能比传统 ECS 方案提升 10~100 倍。通过减少返回列、使用等值查询、避免复杂函数、分区剪枝及压缩优化等技巧,可大幅降低扫描与传输量,显著提升查询效率并降低成本。
220 0