SQL条件分支中的大讲究

在SQL中,条件分支用于根据不同的条件执行不同的操作,适用于数据查询、数据更新以及存储过程等场景。合理使用SQL条件分支,可以优化数据操作流程,提高代码的可读性和可维护性。

目录

1. 逻辑判断的基本概念

2. CASE 语句:多条件判断的利器

2.1 CASE 语句的基本语法

2.2 CASE 在 SELECT 语句中的应用

2.3 CASE 在 UPDATE 语句中的应用

3. IF 语句:适用于存储过程

3.1 IF 语句的基本语法

3.2 在存储过程中的应用

4. IF() 函数:简洁的二元条件判断

4.1 IF() 的基本语法

4.2 在 SELECT 语句中的应用

5. CASE vs IF 的区别

6. 总结


1. 逻辑判断的基本概念

在SQL中,逻辑判断是条件分支的基础,它允许我们根据特定条件筛选数据或执行不同的操作。常见的逻辑运算符有 ANDORNOT,这些运算符用于组合多个条件,实现复杂的判断逻辑。

运算符说明
AND逻辑与,所有条件必须为 TRUE
OR逻辑或,任意一个条件为 TRUE
NOT逻辑非,取反

示例:查询 employees 表中薪资 salary 在 5000 到 10000 之间的员工:

SELECT * FROM employees WHERE salary >= 5000 AND salary <= 10000;

2. CASE 语句:多条件判断的利器

CASE 语句是SQL中最常用的条件分支结构,类似于编程语言中的 switch-case 语句。它能够根据不同的条件返回不同的值,适用于 SELECTUPDATEINSERT 语句。

2.1 CASE 语句的基本语法

CASE 语句的基本语法包括多个 WHEN ... THEN 结构,最终可以使用 ELSE 设定默认返回值。

CASE WHEN 条件1 THEN 结果1WHEN 条件2 THEN 结果2ELSE 默认结果
END

2.2 CASESELECT 语句中的应用

CASE 语句通常用于查询语句中,根据不同的条件返回不同的结果。例如,我们可以根据 employees 表的 salary 字段对员工进行分类。

SELECT employee_id, name, salary,CASE WHEN salary > 10000 THEN '高级'WHEN salary BETWEEN 5000 AND 10000 THEN '中级'ELSE '初级'END AS level
FROM employees;

2.3 CASEUPDATE 语句中的应用

我们还可以在 UPDATE 语句中使用 CASE 语句来批量更新数据,例如根据员工工资调整奖金。

UPDATE employees
SET bonus = CASE WHEN salary > 10000 THEN 2000WHEN salary BETWEEN 5000 AND 10000 THEN 1000ELSE 500END;

3. IF 语句:适用于存储过程

在 MySQL 的存储过程中,我们可以使用 IF 语句进行条件分支,它类似于其他编程语言中的 if-else 语句,适用于执行复杂的业务逻辑。

3.1 IF 语句的基本语法

IF 语句允许在存储过程中执行条件判断,并根据不同的条件执行不同的 SQL 语句。

IF 条件1 THEN语句1;
ELSEIF 条件2 THEN语句2;
ELSE语句3;
END IF;

3.2 在存储过程中的应用

例如,我们可以创建一个存储过程来根据传入的 emp_salary 值返回员工级别。

DELIMITER //
CREATE PROCEDURE check_salary(IN emp_salary INT)
BEGINIF emp_salary > 10000 THENSELECT '高级员工';ELSEIF emp_salary BETWEEN 5000 AND 10000 THENSELECT '中级员工';ELSESELECT '初级员工';END IF;
END //
DELIMITER ;

调用存储过程:

CALL check_salary(7000);

4. IF() 函数:简洁的二元条件判断

IF() 函数是 MySQL 提供的一个内置函数,它用于简单的二元条件判断,类似于编程语言中的三元运算符。适用于 SELECT 语句中的简单条件判断。

4.1 IF() 的基本语法

IF() 函数的基本语法如下,其中 条件TRUE 时返回 值1,否则返回 值2

IF(条件, 值1, 值2)

4.2 在 SELECT 语句中的应用

例如,我们可以使用 IF() 来判断员工薪资是否高于 5000,并返回相应的级别。

SELECT name, salary, IF(salary > 5000, '高薪', '低薪') AS salary_level FROM employees;

5. CASE vs IF 的区别

不同的SQL条件分支适用于不同的场景,以下是它们之间的主要区别。

特性CASE 语句IF 语句IF() 函数
适用范围SELECTUPDATEINSERT仅限存储过程SELECT 语句
支持多条件❌(仅二元条件)
跨数据库支持✅(适用于所有数据库)❌(仅MySQL、PL/SQL)❌(仅MySQL)

6. 总结

在SQL中,不同的条件分支适用于不同的业务需求:

  • CASE 语句:适用于 SELECTUPDATEINSERT,支持多个条件,适用于所有数据库。

  • IF 语句:仅用于存储过程和函数,适用于 MySQL 和 PL/SQL。

  • IF() 函数:MySQL 专用,适用于简单的二元条件判断。

合理选择 SQL 条件分支结构可以优化查询逻辑,提高代码的可读性和执行效率。

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

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

相关文章

VSCode中使用EmmyLua插件对Unity的tolua断点调试

一.VSCode中搜索安装EmmyLua插件 二.创建和编辑launch.json文件 初始的launch.json是这样的 手动编辑加上一段内容如下图所示&#xff1a; 三.启动调试模式&#xff0c;并选择附加的进程

k8sollama部署deepseek-R1模型,内网无坑

这是目录 linux下载ollama模型文件下载到本地,打包迁移到k8s等无网络环境使用下载打包ollama镜像非k8s环境使用k8s部署访问方式非ollama运行deepseek模型linux下载ollama 下载后可存放其他服务器 curl -L https://ollama.com/download/ollama-linux-amd64.tgz -o ollama-linu…

2025年Android NDK超全版本下载地址

Unity3D特效百例案例项目实战源码Android-Unity实战问题汇总游戏脚本-辅助自动化Android控件全解手册再战Android系列Scratch编程案例软考全系列Unity3D学习专栏蓝桥系列ChatGPT和AIGC &#x1f449;关于作者 专注于Android/Unity和各种游戏开发技巧&#xff0c;以及各种资源分…

通信易懂唠唠SOME/IP——SOME/IP-SD服务发现阶段和应答行为

一 SOME/IP-SD服务发现阶划分 服务发现应该包含3个阶段 1.1 Initial Wait Phase初始等待阶段 初始等待阶段的作用 初始等待阶段是服务发现过程中的一个阶段。在这个阶段&#xff0c;服务发现模块等待服务实例的相关条件满足&#xff0c;以便继续后续的发现和注册过程。 对…

1. Kubernetes组成及常用命令

Pods(k8s最小操作单元)ReplicaSet & Label(k8s副本集和标签)Deployments(声明式配置)Services(服务)k8s常用命令Kubernetes(简称K8s)是一个开源的容器编排系统,用于自动化应用程序的部署、扩展和管理。自2014年发布以来,K8s迅速成为容器编排领域的行业标准,被…

Vue全流程--Vue2组件的理解第二部分

组件命名规则 好的命名规则可以省去很多不必要的麻烦&#xff0c;这个好习惯还是要养成的 一个单词组成&#xff1a; 第一种写法(首字母小写)&#xff1a;school 第二种写法(首字母大写)&#xff1a;School 多个单词组成&#xff1a; 第一种写法(kebab-case命名)&#xf…

【OS】AUTOSAR架构下的Interrupt详解(上篇)

目录 前言 正文 1.中断概念分析 1.1 中断处理API 1.2 中断级别 1.3 中断向量表 1.4 二类中断的嵌套 1.4.1概述 1.4.2激活 1.5一类中断 1.5.1一类中断的实现 1.5.2一类中断的嵌套 1.5.3在StartOS之前的1类ISR 1.5.4使用1类中断时的注意事项 1.6中断源的初始化 1.…

红包雨项目前端部分

创建项目 pnpm i -g vue/cli vue create red_pakage pnpm i sass sass-locader -D pnpm i --save normalize.css pnpm i --save-dev postcss-px-to-viewportpnpm i vantlatest-v2 -S pnpm i babel-plugin-import -Dhttps://vant.pro/vant/v2/#/zh-CN/<van-button click&…

深入理解k8s中的容器存储接口(CSI)

CSI出现的原因 K8s原生支持一些存储类型的PV&#xff0c;像iSCSI、NFS等。但这种方式让K8s代码与三方存储厂商代码紧密相连&#xff0c;带来不少麻烦。比如更改存储代码就得更新K8s组件&#xff0c;成本高&#xff1b;存储代码的bug还会影响K8s稳定性&#xff1b;K8s社区维护和…

DeepSeek回答禅宗三重境界重构交易认知

人都是活在各自心境里&#xff0c;有些话通过语言去交流&#xff0c;还是要回归自己心境内在的&#xff0c;而不是靠外在映射到股票和技术方法&#xff1b;比如说明天市场阶段是不修复不接力节点&#xff0c;这就是最高视角看整个市场&#xff0c;还有哪一句话能概括&#xff1…

简单说一下CAP理论和Base理论

CAP理论 什么是CAP 一致性 可用性 分区容错性&#xff1a;系统如果不能再时限内达成数据一致性&#xff0c;就说明发生了分区的情况 然后当前操作在C和A之间做出选择 例如我的网络出现问题了&#xff0c;但是我们的系统不能因为网络问题就直接崩溃 只要我们的分布式系统没…

13.PPT:诺贝尔奖【28】

目录 NO1234 NO567 NO8/9/10 NO11/12 NO1234 设计→变体→字体→自定义字体 SmartArt超链接新增加节 NO567 版式删除图片中的白色背景&#xff1a;选中图片→格式→删除背景→拖拉整个图片→保留更改插入→图表→散点图 &#xff1a;图表图例、网格线、坐标轴和图表标题…

RabbitMQ的安装

1、官网地址 下载地址&#xff1a;Installing RabbitMQ | RabbitMQhttp://www.rabbitmq.com/download.htmlhttp://www.rabbitmq.com/download.html RabbitMQ Documentation | RabbitMQhttps://www.rabbitmq.com/docshttps://www.rabbitmq.com/docs 2、Windows上安装 2.1 安装…

【LeetCode】152、乘积最大子数组

【LeetCode】152、乘积最大子数组 文章目录 一、dp1.1 dp1.2 简化代码 二、多语言解法 一、dp 1.1 dp 从前向后遍历, 当遍历到 nums[i] 时, 有如下三种情况 能得到最大值: 只使用 nums[i], 例如 [0.1, 0.3, 0.2, 100] 则 [100] 是最大值使用 max(nums[0…i-1]) * nums[i], 例…

【分布式理论六】分布式调用(4):服务间的远程调用(RPC)

文章目录 一、RPC 调用过程二、RPC 动态代理&#xff1a;屏蔽远程通讯细节1. 动态代理示例2. 如何将动态代理应用于 RPC 三、RPC 序列化四、RPC 协议编码1. 协议编码的作用2. RPC 协议消息组成 五、RPC 网络传输1. 网络传输流程2. 关键优化点 一、RPC 调用过程 RPC&#xff08…

Spring Task之Cron表达式

&#x1f31f; Spring Task高能预警&#xff1a;你以为的Cron表达式可能都是错的&#xff01;【附实战避坑指南】 开篇暴击&#xff1a;为什么你的定时任务总在凌晨3点翻车&#xff1f; “明明设置了0 0 2 * * ?&#xff0c;为什么任务每天凌晨3点执行&#xff1f;” —— 来…

第16章 Single Thread Execution设计模式(Java高并发编程详解:多线程与系统设计)

简单来说&#xff0c; Single Thread Execution就是采用排他式的操作保证在同一时刻只能有一个线程访问共享资源。 1.机场过安检 1.1非线程安全 先模拟一个非线程安全的安检口类&#xff0c;旅客(线程)分别手持登机牌和身份证接受工作人员的检查&#xff0c;示例代码如所示。…

OSPF基础(2):数据包详解

OSPF数据包(可抓包) OSPF报文直接封装在IP报文中&#xff0c;协议号89 头部数据包内容&#xff1a; 版本(Version):对于OSPFv2&#xff0c;该字段值恒为2(使用在IPV4中)&#xff1b;对于OSPFv3&#xff0c;该字段值恒为3(使用在IPV6中)。类型(Message Type):该OSPF报文的类型。…

MAC 安装mysql全过程记录

4.然后等待下载吧&#xff0c;&#xff08;下载中。。。。&#xff09;&#xff0c;好了&#xff0c;网速的问题&#xff0c;半个小时终于下载好了&#xff0c;开始安装吧。 5.得到如下安装包&#xff0c;mac下也是双击直接下载&#xff0c;来&#xff0c;我们来看看下载的过程…

神经网络常见激活函数 1-sigmoid函数

sigmoid 1 函数求导 sigmoid函数 σ ( x ) 1 1 e ( − x ) \sigma(x) \frac{1}{1e^{(-x)}} σ(x)1e(−x)1​ sigmoid函数求导 d d x σ ( x ) d d x ( 1 1 e − x ) e − x ( 1 e − x ) 2 ( 1 e − x ) − 1 ( 1 e − x ) 2 1 1 e − x − 1 ( 1 e − x ) 2 …