SQL 中复杂 CASE WHEN 嵌套逻辑优化

目标:优化复杂的 CASE WHEN 逻辑,提升 SQL 语句的可读性与执行效率,减少多层嵌套带来的复杂性。


1. CASE WHEN 的常见问题

  • 嵌套过深:多个条件判断嵌套,难以阅读和维护。
  • 重复逻辑:相似逻辑在多个分支中重复出现,代码冗余。
  • 性能瓶颈:大量嵌套会导致查询执行变慢,特别是在大表中。

2. 需求描述

根据订单金额计算折扣,同时针对不同会员等级提供额外折扣。

  • 普通用户:订单金额 ≥ 1000,打9折;金额 < 1000,无折扣。
  • VIP 用户:订单金额 ≥ 800,打8折;金额 < 800,打9折。
  • SVIP 用户:订单金额 ≥ 500,打7折;金额 < 500,打8折。

3. 示例数据

orders 表结构:

order_iduser_idamountmembership_level
11011200normal
2102700vip
3103450svip
4104300normal

4. 复杂嵌套 SQL 示例(待优化)

SELECT order_id,user_id,amount,membership_level,CASE WHEN membership_level = 'normal' THEN CASE WHEN amount >= 1000 THEN amount * 0.9ELSE amountENDWHEN membership_level = 'vip' THEN CASE WHEN amount >= 800 THEN amount * 0.8ELSE amount * 0.9ENDWHEN membership_level = 'svip' THEN CASE WHEN amount >= 500 THEN amount * 0.7ELSE amount * 0.8ENDELSE amountEND AS final_amount
FROM orders;

5. 问题分析

  • 重复代码CASE WHEN 逻辑中存在大量重复的条件判断逻辑。
  • 嵌套复杂:三个不同会员等级分别嵌套了 CASE,不易维护。

6. 优化策略

  1. 平铺逻辑:减少嵌套,直接平铺条件。
  2. 按条件分层:优先判断会员等级,降低嵌套层级。
  3. 使用 IF 和 IFNULL 简化逻辑:避免多层嵌套。

7. 优化后 SQL 实现

SELECT order_id,user_id,amount,membership_level,amount * CASE WHEN membership_level = 'normal' AND amount >= 1000 THEN 0.9WHEN membership_level = 'vip' AND amount >= 800 THEN 0.8WHEN membership_level = 'vip' AND amount < 800 THEN 0.9WHEN membership_level = 'svip' AND amount >= 500 THEN 0.7WHEN membership_level = 'svip' AND amount < 500 THEN 0.8ELSE 1.0END AS final_amount
FROM orders;

8. 优化亮点

  • 单层 CASE:通过合并条件,消除嵌套。
  • 性能提升:减少 SQL 扫描逻辑,提高执行效率。
  • 代码简洁:结构更清晰,易于阅读和维护。

9. 进一步优化(分层条件逻辑)

SELECT order_id,user_id,amount,membership_level,amount * IFNULL((SELECT discountFROM (SELECT 'normal' AS level, 1000 AS threshold, 0.9 AS discountUNION ALLSELECT 'vip', 800, 0.8UNION ALLSELECT 'vip', 0, 0.9UNION ALLSELECT 'svip', 500, 0.7UNION ALLSELECT 'svip', 0, 0.8) AS discountsWHERE orders.membership_level = discounts.level AND orders.amount >= discounts.thresholdORDER BY threshold DESCLIMIT 1), 1.0) AS final_amount
FROM orders;

10. 解释

  • 子查询优化:将折扣条件作为子查询,通过动态匹配减少主查询逻辑复杂度。
  • IFNULL 处理默认值:若无匹配条件,返回原始金额 1.0
  • 扩展性强:新增折扣规则时,只需在子查询内新增记录,主查询无需修改。

11. 结果示例

order_iduser_idamountmembership_levelfinal_amount
11011200normal1080.00
2102700vip630.00
3103450svip360.00
4104300normal300.00

12. 总结

  • 复杂 CASE WHEN 的嵌套逻辑可以通过平铺逻辑子查询分层简化,提升 SQL 可读性和执行效率。
  • 合理使用 IFNULLIF 减少空值和异常情况带来的错误风险。
  • 动态折扣方案可以通过表驱动或子查询方式实现,便于维护和扩展。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/501324.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

杰盛微 JSM4056 1000mA单节锂电池充电器芯片 ESOP8封装

JSM4056 1000mA单节锂电池充电器芯片 JSM4056是一款单节锂离子电池恒流/恒压线性充电器&#xff0c;简单的外部应用电路非常适合便携式设备应用&#xff0c;适合USB电源和适配器电源工作&#xff0c;内部采用防倒充电路&#xff0c;不需要外部隔离二极管。热反馈可对充电电流进…

Linux实验报告14-Linux内存管理实验

目录 一&#xff1a;实验目的 二&#xff1a;实验内容 1、编辑模块的源代码mm_viraddr.c 2、编译模块 3、编写测试程序mm_test.c 4、编译测试程序mm_test.c 5、在后台运行mm_test 6、验证mm_viraddr模块 一&#xff1a;实验目的 (1)掌握内核空间、用户空间&#xff…

供需平台信息发布付费查看小程序系统开发方案

供需平台信息发布付费查看小程序系统主要是为了满足个人及企业用户的供需信息发布与匹配需求。 一、目标用户群体 个人用户&#xff1a;寻找兼职工作、二手物品交换、本地服务&#xff08;如家政、维修&#xff09;等。 小微企业&#xff1a;推广产品和服务&#xff0c;寻找合…

overleaf写学术论文常用语法+注意事项+审阅修订

常用语法 导入常用的宏包 \usepackage{cite} \usepackage{amsmath,amssymb,amsfonts} \usepackage{algorithmic} \usepackage{algorithm} \usepackage{graphicx} \usepackage{subfigure} \usepackage{textcomp} \usepackage{xcolor} \usepackage{lettrine} \usepackage{booktab…

动态规划<八> 完全背包问题及其余背包问题

目录 例题引入---找到解决问题模版 LeetCode 经典OJ题 1.第一题 2.第二题 3.第三题 其余的一些背包问题 1.二维费用的背包问题 例题引入---找到解决问题模版 OJ 传送门 牛客 DP42 【模板】完全背包 画图分析: 使用动态规划解决(第二问与第一问的不同之处用绿色来标记) 1.…

TP8 前后端跨域访问请求API接口解决办法

报错&#xff1a;Access to XMLHttpRequest at http://www.e.com/api/v1.index/index?t1735897901267 from origin http://127.0.0.1:5500 has been blocked by CORS policy: Response to preflight request doesnt pass access control check: The value of the Access-Contr…

【前端系列】Pinia状态管理库

文章目录 一、前言&#x1f680;&#x1f680;&#x1f680;二、Pinia状态管理库&#xff1a;☀️☀️☀️2.1 pinia基本使用① pinia充当中转站存放token② 使用步骤 2.1 axios请求拦截器 一、前言&#x1f680;&#x1f680;&#x1f680; ☀️ 回报不在行动之后&#xff0c;…

打造三甲医院人工智能矩阵新引擎(四):医疗趋势预测大模型篇 EpiForecast与DeepHealthNet合成应用

一、引言 1.1 研究背景与意义 在当今数字化时代,医疗领域积累了海量的数据,涵盖电子病历、医学影像、基因序列、临床检验结果等多源异构信息。这些数据蕴含着疾病发生发展、治疗反应、疫情传播等规律,为医疗趋势预测提供了数据基础。准确的医疗趋势预测能辅助医疗机构提前…

C# 服务调用RFC函数获取物料信息,并输出生成Excel文件

这个例子是C#服务调用RFC函数&#xff0c;获取物料的信息&#xff0c;并生成Excel文件 上接文章&#xff1a;C#服务 文章目录 创建函数创建结构编写源代码创建批处理文件运行结果-成功部署服务器C#代码配置文件注意&#xff01;&#xff01; 创建函数 创建结构 编写源代码 创建…

OFDM学习-(二)长短序列和PPDU整体数据处理流程

OFDM学习 &#xff08;二&#xff09;长短序列和PPDU整体数据处理流程 OFDM学习前言一、短序列短序列的作用 二、长序列三、PLCP/SIGNAL/DATA数据处理流程三、fpga实现STS模块LTS模块训练序列模块仿真波形 总结 前言 根据框图可以知道发射机这部分信号在DA转换之前&#xff0c…

leetcode 173.二叉搜索树迭代器栈绝妙思路

以上算法题中一个比较好的实现思路就是利用栈来进行实现&#xff0c;以下方法三就是利用栈来进行实现的&#xff0c;思路很好&#xff0c;很简练。进行next的时候&#xff0c;先是一直拿到左边的子树&#xff0c;直到null为止&#xff0c;这一步比较好思考一点&#xff0c;下一…

商用车自动驾驶,迎来大规模量产「临界点」?

商用车自动驾驶&#xff0c;正迎来新的行业拐点。 今年初&#xff0c;交通部公开发布AEB系统运营车辆标配征求意见稿&#xff0c;首次将法规限制条件全面放开&#xff0c;有望推动商用车AEB全面标配&#xff0c;为开放场景的商用车智能驾驶市场加了一把火。 另外&#xff0c;…

kubernetes学习-kubectl命令、探针(二)

一、在任意节点使用 kubectl # 在master节点获取节点信息 [rootk8s-master k8s]# kubectl get nodes NAME STATUS ROLES AGE VERSION k8s-master Ready control-plane,master 16h v1.23.6 k8s-node1 Ready <none> …

关于IDE的相关知识之三【插件安装、配置及推荐的意义】

成长路上不孤单&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a; 【14后&#x1f60a;///C爱好者&#x1f60a;///持续分享所学&#x1f60a;///如有需要欢迎收藏转发///&#x1f60a;】 今日分享关于ide插件安装、配置及推荐意义的相关内容…

Node 如何生成 RSA 公钥私钥对

一、引入crypto模块 crypto 为node 自带模块&#xff0c;无需安装 const crypto require(crypto);二、封装生成方法 async function generateRSAKeyPair() {return new Promise((resolve, reject) > {crypto.generateKeyPair(rsa, {modulusLength: 2048, // 密钥长度为 …

数字PWM直流调速系统设计(论文+源码)

2.1 系统方案设计 2.2.1开环控制方案 采用开环方案的系统架构如图2.1所示&#xff0c;这种方式不需要对直流电机的转速进行检测&#xff0c;在速度控制时单片机只需要直接发出PWM就可以实现直流电机速度的控制。这种方式整体设计难度较低&#xff0c;但是无法准确得知当前的…

w~多模态~合集1

我自己的原文哦~ https://blog.51cto.com/whaosoft/12663226 #Vista-LLaMA Vista-LLaMA 在处理长视频内容方面的显著优势&#xff0c;为视频分析领域带来了新的解决框架。AI解读视频张口就来&#xff1f;这种「幻觉」难题给解决了 近年来&#xff0c;大型语言模型如 GPT、…

2025年第五届控制理论与应用国际会议 | Ei Scopus双检索

会议简介 Brief Introduction 2025年第五届控制理论与应用国际会议(ICoCTA 2025) 会议时间&#xff1a;2025年9月19 -21日 召开地点&#xff1a;中国成都 大会官网&#xff1a;www.icocta.org 控制理论作为一门科学技术&#xff0c;已经广泛地运用于我们社会生活方方面面。随着…

SASS 简化代码开发的基本方法

概要 本文以一个按钮开发的实例&#xff0c;介绍如何使用SASS来简化CSS代码开发的。 代码和实现 我们希望通过CSS开发下面的代码样式&#xff0c;从样式来看&#xff0c;每个按钮的基本样式相同&#xff0c;就是颜色不同。 如果按照传统的方式开发&#xff0c;需要开发btn &…

项目:停车场车辆管理系统

这个代码实现了一个停车场管理系统&#xff0c;主要功能包括车辆信息的添加、删除、修改、查找、显示所有车辆信息、排序以及计算停车费用。系统使用双向链表来存储车辆数据&#xff0c;并提供了菜单驱动的界面供用户选择不同的操作。 主要功能描述&#xff1a; 添加车辆信息&…