news 2026/4/3 1:26:10

【扫盲】sql代码里那个“傻鸟” 1=1 到底是个啥?为什么 MyBatis 不用写?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【扫盲】sql代码里那个“傻鸟” 1=1 到底是个啥?为什么 MyBatis 不用写?

【扫盲】sql代码里那个“傻鸟” 1=1 到底是个啥?为什么 MyBatis 不用写?

很多刚接手旧项目(特别是用 Hibernate/HQL 或 JDBC)的兄弟,第一次看到类似下面的代码时,内心往往是崩溃的:

SELECT * FROM user WHERE 1=1 AND name = '张三'

此时你的脑海里一定会弹幕刷屏:

  • “写这代码的人是不是有病?”
  • “1=1 不是废话吗?还要数据库算一下?”
  • “为什么我写 MyBatis XML 的时候从来不用这招?”

别急,存在即合理。今天咱们就来扒一扒这个“傻鸟”1=1到底是为了解决什么千古难题。


一、 那个“傻鸟” 1=1,其实是“拼”出来的无奈

首先你要明白一个核心区别:

  • 你眼里的 SQL:是写在 XML 里或者 Navicat 里的,是静态的。
  • Java 程序里的 SQL:是根据用户点选的条件,动态拼接出来的字符串。
场景还原

假设你做一个“人员搜索”功能,有三个输入框:姓名年龄电话。用户想填哪个填哪个。

如果不用 1=1,你的 Java 代码得写成这样(地狱模式):

String sql = "SELECT * FROM user"; boolean isFirstCondition = true; // 搞个标记,判断是不是第一个条件 // 1. 处理姓名 if (name != null) { if (isFirstCondition) { sql += " WHERE name = '" + name + "'"; // 第一个不能加 AND isFirstCondition = false; // 标记改为false } else { sql += " AND name = '" + name + "'"; } } // 2. 处理年龄 if (age != null) { if (isFirstCondition) { // 每次都要判断是不是第一个!烦死! sql += " WHERE age = " + age; isFirstCondition = false; } else { sql += " AND age = " + age; } }

看到没有?为了确定**“谁是第一个条件”**(第一个条件前要加WHERE,后面的要加AND),程序员不得不写一堆恶心的if-else判断。

这时候,聪明的程序员想了一招(懒人模式):

既然不知道谁是第一个,那我就先人为造一个永远为真的“假条件”放在第一个

// 先把 WHERE 1=1 扔这占坑 String sql = "SELECT * FROM user WHERE 1=1"; // 后面所有人,统统无脑加 "AND"! if (name != null) { sql += " AND name = '" + name + "'"; } if (age != null) { sql += " AND age = " + age; }

真相大白:

1=1 的作用就是一个**“转接头”**。它占住了 WHERE 后面第一个位置,让后面所有的条件都可以统一用 AND 开头,彻底消灭了繁琐的判断逻辑。


二、 为什么 MyBatis 的 XML 里没有?

你说:“我在 MyBatis 里写动态查询,也是三个框随便填,为啥我不写 1=1?”

那是因为MyBatis 把你当宝宝宠坏了。并不是不需要处理这个问题,而是 MyBatis 默默在后台帮你把这活儿干了。

来看看 MyBatis 的神器 ——<where>标签

MyBatis 的写法:
<select id="findUser"> SELECT * FROM user <where> <if test="name != null"> AND name = #{name} </if> <if test="age != null"> AND age = #{age} </if> </where> </select>
MyBatis 在后台干的“脏活累活”:

当 MyBatis 解析这个<where>标签时,它运行了一套智能逻辑:

  1. 自动检测内容:如果<where>标签里没有任何条件满足(用户啥都没填),它就不生成 WHERE 关键字
  2. 自动去头:如果标签里有内容,且内容是以ANDOR开头的,它会自动帮你把第一个 AND 删掉

对比一下:

  • HQL/JDBC 拼接字符串:就像手动挡汽车,离合、换挡都要你自己操作(必须写1=1占位)。
  • MyBatis XML:就像自动挡+辅助驾驶,你只管踩油门(写AND),系统自动帮你判断什么时候挂档(处理WHERE和去掉多余的AND)。

三、 灵魂拷问:写 1=1 会影响性能吗?

很多有洁癖的程序员会担心:“数据库执行的时候,还要专门算一下 1 等不等于 1,这不多余吗?”

答案:完全不会。

现在的数据库(MySQL、Oracle)都贼精明。它们的**查询优化器(Optimizer)**在拿到 SQL 的第一瞬间,就会把1=1这种恒为真的废话给优化掉。

在数据库眼里:

SELECT * FROM user WHERE 1=1 AND age=18

↓ 自动优化为 ↓

SELECT * FROM user WHERE age=18

所以,性能损耗为0


四、 总结

  1. HQL / JDBC 里的1=1:不是傻,是智慧的妥协。它是为了在纯字符串拼接时代,简化代码逻辑、避免if-else地狱的必要手段。
  2. MyBatis 里的清爽:不是因为问题消失了,而是框架提供了**<where>标签**,在底层帮你完成了“去多余 AND”的操作。
  3. 以后见到1=1:不要骂它傻鸟,请瑞思拜(Respect)。那是老一代程序员为了偷懒…哦不,为了代码整洁留下的智慧结晶。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/18 20:25:56

Tarjan算法图论全家桶--点双联通分量

定义 在无向图G(V,E)中&#xff0c;如果删除任意一个节点&#xff08;及其关联的边&#xff09;后&#xff0c;子图仍然连通&#xff0c;则称这个子图是点连通的。 点双连通分量&#xff08;Vertex Biconnected Component, vDCC&#xff09;&#xff1a;图的极大点连通子图。 重…

作者头像 李华
网站建设 2026/3/25 17:28:24

MyMind 多维思维导图项目日报(2025.12.17)

日期&#xff1a;2025-12-17项目名称&#xff1a;MyMind 多维思维导图项目阶段&#xff1a;Beta 阶段总结 & 对外验证一、今日完成1. 用户问卷数据整理与分析对 Beta 阶段发放的用户问卷进行完整整理与分析&#xff08;共 56 份有效样本&#xff09;&#xff0c;重点关注真…

作者头像 李华
网站建设 2026/3/29 9:08:24

扫描网站结构的SEO元数据抓取方案

扫描网站结构的SEO元数据抓取方案 &#x1f308;你好呀&#xff01;我是 是Yu欸 &#x1f680; 感谢你的陪伴与支持~ 欢迎添加文末好友 &#x1f30c; 在所有感兴趣的领域扩展知识&#xff0c;不定期掉落福利资讯(*^▽^*) 版权声明&#xff1a;本文为原创&#xff0c;遵循 CC…

作者头像 李华
网站建设 2026/3/26 11:44:52

【收藏必备】大模型RAG技术全解析:零基础也能掌握的检索增强生成技术

RAG&#xff08;检索增强生成&#xff09;是一种将大语言模型与外部知识源结合的技术&#xff0c;通过索引、检索和生成三个步骤弥补LLM的知识局限。文章详细介绍了RAG的基本原理、技术流程、系统构建方法、效果评估指标以及优化策略&#xff0c;包括查询优化、高级检索、语义路…

作者头像 李华