news 2026/6/23 11:44:28

开发过程中动态 SQL 中where 1=1的作用是什么

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
开发过程中动态 SQL 中where 1=1的作用是什么

在这条 MyBatis 动态 SQL 中,where 1=1动态拼接 WHERE 条件的经典技巧,核心作用是:解决 “第一个动态条件前是否需要加 AND” 的问题,让条件拼接逻辑更简洁、无歧义

一、先看核心问题:没有1=1会怎样?

假设去掉where 1=1,SQL 会变成:

where <if test="query.shopIdList != null and query.shopIdList.size()>0"> and a.shopId in (...) </if> <if test="query.shopId != null and query.shopId != ''"> and a.shopId=#{query.shopId} </if> ...

如果第一个动态条件不满足(比如shopIdList为 null),最终拼接的 SQL 会是:

select ... from dws_shop_itemcate_sum a where and a.shopId=xxx

where后直接跟and,触发SQL 语法错误BadSqlGrammarException)。

二、where 1=1的核心作用

1=1是一个恒成立的条件(不会过滤任何数据),但它能:

  1. 占住where后的第一个位置,所有动态条件都可以统一以and开头,无需判断 “是不是第一个条件”;
  2. 不影响查询结果1=1永远为真,不会过滤任何数据,最终的查询结果只由后续的动态条件决定;
  3. 简化逻辑:开发时不用逐个判断 “当前条件是不是第一个”,所有动态条件都按and 条件写即可,降低出错概率。

三、代码执行示例(更直观)

场景 1:仅传shopIdList([9001,9002])

最终拼接的 SQL:

select ... from dws_shop_itemcate_sum a where 1=1 and a.shopId in (9001,9002)
场景 2:仅传shopId(9003)+beginTime(2025-01-01)

最终拼接的 SQL:

select ... from dws_shop_itemcate_sum a where 1=1 and a.shopId=9003 and a.reportDate>='2025-01-01'
场景 3:不传任何动态条件

最终拼接的 SQL:

select ... from dws_shop_itemcate_sum a where 1=1

(等价于select ... from dws_shop_itemcate_sum a,查询全表)

四、替代方案(MyBatis 更优雅的写法)

MyBatis 提供了<where>标签,可以替代1=1,自动处理多余的and/or

<select id="sumNumberCardDataByShop" resultType="StNumberCardDataBO"> select <include refid="numberCard_queryColumn"/> from dws_shop_itemcate_sum a <where> <!-- 替代 where 1=1 --> <if test="query.shopIdList != null and query.shopIdList.size()>0"> a.shopId in <!-- 去掉 and --> <foreach collection="query.shopIdList" item="shopId" index="index" open="(" close=")" separator=","> #{shopId} </foreach> </if> <if test="query.shopId != null and query.shopId != ''"> and a.shopId=#{query.shopId} <!-- 保留 and --> </if> <if test="query.beginTime != null and query.beginTime !=''"> <![CDATA[ and a.reportDate>=#{query.beginTime} ]]> </if> <if test="query.endTime != null and query.endTime !=''"> <![CDATA[ and a.reportDate<=#{query.endTime}]]> </if> </where> </select>
<where>标签的优势:
  • 若有动态条件满足:自动添加where,并去掉第一个条件前的and/or
  • 若没有动态条件满足:不生成where子句(避免where 1=1全表查询);
  • 1=1更优雅,是 MyBatis 推荐的写法。

五、总结

  1. where 1=1的本质:用恒真条件占位,让所有动态条件统一以and开头,避免语法错误
  2. 优缺点:
    • 优点:简单易懂,新手友好;
    • 缺点:若所有动态条件都不满足,会生成where 1=1导致全表查询(可能性能低);
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 15:26:45

洛谷 P1551 亲戚

题目背景若某个家族人员过于庞大&#xff0c;要判断两个是否是亲戚&#xff0c;确实还很不容易&#xff0c;现在给出某个亲戚关系图&#xff0c;求任意给出的两个人是否具有亲戚关系。题目描述规定&#xff1a;x 和 y 是亲戚&#xff0c;y 和 z 是亲戚&#xff0c;那么 x 和 z …

作者头像 李华
网站建设 2026/6/23 20:25:09

d2s-editor终极指南:暗黑破坏神2存档修改完全教程

d2s-editor终极指南&#xff1a;暗黑破坏神2存档修改完全教程 【免费下载链接】d2s-editor 项目地址: https://gitcode.com/gh_mirrors/d2/d2s-editor 暗黑破坏神2作为经典ARPG游戏&#xff0c;其存档系统承载着玩家的游戏历程。d2s-editor这款强大的游戏存档编辑工具&…

作者头像 李华
网站建设 2026/6/23 1:49:40

UniExtract2深度评测:万能文件提取工具的技术解析与实战应用

第一部分&#xff1a;技术痛点分析 【免费下载链接】UniExtract2 Universal Extractor 2 is a tool to extract files from any type of archive or installer. 项目地址: https://gitcode.com/gh_mirrors/un/UniExtract2 在数据资源管理日益复杂的今天&#xff0c;技术…

作者头像 李华
网站建设 2026/6/23 8:44:01

MySQL主从数据同步实战

什么是数据同步&#xff1f;想想这样一个场景&#xff1a;今天10点开放考试成绩查询的入口&#xff0c;那么在10点钟会有一大波流量高峰&#xff0c;一台服务器肯定扛不住了。而且这种情况几乎没有数据更新操作&#xff0c;都是数据查询。类似这样的查询请求非常高的情况下&…

作者头像 李华
网站建设 2026/6/23 19:46:29

破局Java开发困境!飞算科技JavaAI引领智能化开发新革命

在软件开发领域&#xff0c;Java作为应用场景广泛的主流编程语言&#xff0c;其工程开发环节正遭遇效率瓶颈凸显、代码质量不稳定、人力成本持续攀升等多重难题。推动Java工程智能化升级&#xff0c;已然成为行业实现高质量发展亟待破解的核心命题。飞算数智科技&#xff08;深…

作者头像 李华
网站建设 2026/6/23 19:23:26

21、Yocto项目应用开发全解析

Yocto项目应用开发全解析 1. 应用开发调试与工作流概述 在应用开发过程中,调试是必不可少的环节。若要调试应用,可在源代码上设置断点,然后点击“调试”按钮。 Yocto项目进行应用开发时,推荐使用标准或可扩展的Yocto SDK,作为应用开发者与系统集成者之间的迭代接口。系…

作者头像 李华