news 2026/5/15 20:51:31

SQL 中 OR 与 UNION ALL选择指南

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SQL 中 OR 与 UNION ALL选择指南

一句话总结

  • 普通小表、无索引场景:用OR更简单、代码更短
  • 大表、有索引场景:用UNION ALL性能远优于 OR
  • 需要去重:必须用UNION(性能比 UNION ALL 差)

核心区别

  • 只扫描一次表 / 索引
  • 数据库需要同时判断两个条件
  • 致命问题大多数情况下,OR 会导致索引失效,变成全表扫描
  • 比如:WHERE id=1 OR name='test',即使 id、name 都有索引,数据库也可能两个索引都不用

2. UNION ALL 的工作原理

  • 执行两次独立查询
  • 每个查询都可以独立使用自己的索引
  • 结果直接拼接,不做去重
  • 性能优势:大数据量下,比 OR快几倍~几十倍

3. UNION(不带 ALL)

  • 会对最终结果去重 + 排序
  • 性能比 UNION ALL 差很多
  • 只有你必须去重时才用

什么时候必须用 OR?

  1. 小表 / 测试数据(几百、几千条)

    • 数据量太小,性能差异可以忽略
    • OR 代码更简洁
  2. 两个条件依赖同一行数据的关联判断

WHERE (a=1 AND b=2) OR (a=3 AND b=4)

什么时候必须用 UNION ALL?

  1. 大表、生产环境、追求速度
  2. 查询条件可以命中不同索引
-- id 有索引,name 有索引 SELECT * FROM t WHERE id=100 UNION ALL SELECT * FROM t WHERE name='abc'

3.避免 OR 导致的索引失效

最终选择规则(背会这 3 条)

  1. 有索引 + 数据量大UNION ALL(首选)
  2. 无索引 + 数据量小OR(简洁)
  3. 需要去重UNION(没办法)
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/15 20:48:04

ubuntu服务器部署ai应用如何通过taotoken管理多模型api成本

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 Ubuntu 服务器部署 AI 应用如何通过 Taotoken 管理多模型 API 成本 在 Ubuntu 服务器上部署和运维 AI 应用时,一个常见…

作者头像 李华
网站建设 2026/5/15 20:45:36

开源业务技能知识库:从技术思维到商业思维的实战指南

1. 项目概述:一个面向业务技能提升的开源知识库最近在GitHub上闲逛,发现了一个挺有意思的项目,叫ANVEAI/openclaw-business-skills。光看名字,你可能会觉得这又是一个普通的“商业技能”资料合集,但点进去仔细研究后&a…

作者头像 李华
网站建设 2026/5/15 20:45:31

机器人之眼大洗牌:dToF凭什么成为3D感知新王者?

在机器人、自动驾驶、工业自动化和智能物流蓬勃发展的今天,"如何精准感知三维世界"已成为整个行业最核心的命题之一。深度感知技术,赋予了机器一双能够测量距离、理解空间的"眼睛"。从微软2010年发布的Kinect,到苹果2017…

作者头像 李华
网站建设 2026/5/15 20:41:23

企业级应用如何通过下载统一SDK集成Taotoken管理大模型调用

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 企业级应用如何通过下载统一SDK集成Taotoken管理大模型调用 对于需要同时接入多个大模型服务的企业开发团队而言,管理分…

作者头像 李华