三、函数-5.流程函数

news2024/11/23 13:55:48

一、常见函数

 【对比】

二、示例

1、if 和 ifnull

-- if(value, t, f)	如果value为true,则返回t,否则返回f       ok
select if(true, 'ok', 'error');

-- ifnull(value1, value2)	如果value1不为空,返回value1,否则返回value2,为空的意思是null
select ifnull('ok', 'default');    /* ok  */
select ifnull('', 'default');    /* ok  */
select ifnull(null, 'default');    /* default  */

2、case ... when .. then .. else ... end

case [ expr ] when [ val1 ] then [ res1 ] … else [ default ] end

如果expr的值等于val1,返回res1,… 否则返回default默认值

【例】

查询emp表的员工姓名和工作地址(北京/上海 ---> 一线城市, 其他 ---> 二线城市)

step1. 查询emp表的员工姓名和工作地址

select
    name,
    workaddress
from emp;

step2.工作地址做条件判断和转换 case when ... then ... else  ... end

-- case [ expr ] when [ val1 ] then [ res1 ] … else [ default ] end 如果expr的值等于val1,返回res1,… 否则返回default默认值
select
    name,
    (case workaddress when '北京' then '一线城市' when '上海' then '一线城市' else '二线城市' end) as '工作地址'
from emp;

 

3、case when .. then .. else ... end

case when [ val1 ] then [ res1 ] … else [ default ] end

如果val1为true,返回res1,… 否则返回default默认值

【例】

统计班级各个学员的成绩,展示规则如下:

>=85,优秀

>=60,及格

否则,不及格

step1.准备学员成绩表

create table score(
    id int comment 'id',
    name varchar(20) comment '姓名',
    math int comment '数学',
    english int comment '英语',
    chinese int comment '语文'
) comment '学员成绩表';
insert into score (id, name, math, english, chinese)
VALUES (1,  'Tom', 67, 88, 95),
       (2,  'Rose', 23, 66, 90),
       (3, 'Jack', 56, 98, 76);

step2.筛选判断分数区间 case when

select
    id,
    name,
    (case when math>=85 then '优秀' when math>=60 then '及格' else '不及格' end) as '数学成绩',
    (case when english>=85 then '优秀' when english>=60 then '及格' else '不及格' end) as '英语成绩',
    (case when chinese>=85 then '优秀' when chinese>=60 then '及格' else '不及格' end) as '语文成绩'
from score;

 
 

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MFC表格控件CListCtrl的改造及用法

1、目的 简单描述MFC的表格控件使用方法。Qt适用习惯了以后MFC用的比较别扭,因此记录一下以备后续复制代码使用。由于MFC原生的CListCtrl比较局限,比如无法改变表格的背景色、文字颜色等设定,因此先对CListCtrl类进行重写,以便满足…

哪些报表工具更适合中国企业?看完本文就知道了

企业级报表工具是指能够处理大量数据、支持多种数据源连接、具有强大的数据分析和可视化功能的工具。进入大数据时代,企业数据量剧增、分析需求精细化且要求高效率、高灵活自主性,一般都采用BI报表工具来做智能化、可视化数据分析,推动企业的…

Neo4j数据库中导入CSV示例数据

本文简要介绍Neo4j数据库以及如何从CSV文件中导入示例数据,方便我们快速学习测试图数据库。首先介绍简单数据模型以及基本图查询概念,然后通过LOAD CSV命令导入数据,生成节点和关系。 环境准备 读者可以快速安装Neo4j Desktop,启…

Mysql中(@i:=@i+1)的介绍

i:i1 表达式 生成伪列实现自增序列 语法: select (i:i1) as ,t.* from table_name t,(select i:0) as j (i:i1)代表定义一个变量,每次叠加 1; (select i:0) as j 代表建立一个临时表,j是随便取的表名,但别名一定…

python和c++哪个更值得学,python和c++学哪个简单

大家好,本文将围绕python和c哪个更值得学展开说明,python和c学哪个简单是一个很多人都想弄明白的事情,想搞清楚c和python哪个好学需要先了解以下几个事情。 1、想学编程,选择Python 还是Java或者C? 首先,我…

MySQL索引失效原因及解决方案

MySQL索引失效原因及解决方案 在使用MySQL数据库时,索引是一种重要的性能优化工具。然而,有时候我们可能会遇到索引失效的情况。本文将介绍几种常见的MySQL索引失效原因以及相应的解决方案,并提供SQL语句的错误示例和正确示例。 1. 字符串字…

HarmonyOS学习路之方舟开发框架—学习ArkTS语言(状态管理 二)

Prop装饰器:父子单向同步 Prop装饰的变量可以和父组件建立单向的同步关系。Prop装饰的变量是可变的,但是变化不会同步回其父组件。 概述 Prop装饰的变量和父组件建立单向的同步关系: Prop变量允许在本地修改,但修改后的变化不会…

tinkerCAD案例:11.制作齿轮

tinkerCAD案例:11.制作齿轮 制作齿轮 Add a cylinder to be the main part of the gear. 添加一个圆柱体作为齿轮的主要部分。 说明 Click and drag a cylinder onto the Workplane. 单击圆柱体并将其拖动到工作平面上。 Change the cylinder dimensions to 35mm …

四、约束-1.概述

一、概念 约束是作用于表中字段上的规则,用于限制存储在表中的数据。 二、目的 保证数据库中数据的正确、有效性和完整性。 三、分类

视觉套件专项活动!与飞桨技术专家一起提升技术实力,更多荣誉奖励等你领取

作为中国最早开源的深度学习框架,飞桨深度践行开源理念,开放拥抱社区,重视生态构建,与开发者和生态伙伴共成长,已成为国内综合竞争力第一的产业级深度学习平台。截至目前,飞桨已凝聚750万名开发者。 在飞桨…

i.MX6ULL(十九) linux gpio子系统

一 简介 pinctrl 子系统重点是设置 PIN( 有的 SOC 叫做 PAD) 的复用 和电气属性, 如果 pinctrl 子系统将一个 PIN 复用为 GPIO 的话,那么接下来就要用到 gpio 子系 统了。gpio 子系统顾名思义,就是用于初始化 GPIO 并且提供相…

idea,选中同一个变量高亮显示

阅读复杂代码时,我们经常因为找不清变量位置,而浪费精力重新去看变量名。 效果展示: 在设置里直接搜索按照步骤,勾选然后修改选中变量时的变量背景颜色和字体颜色 这里是设置选中变量时,其他变量的背景颜色和字体颜色…

终于搞懂!数字化、信息化、智能化,到底有什么不同?

引言 随着科技的飞速发展,数字化、信息化和智能化这三个术语在各行各业中频繁出现。然而,许多人对它们之间的区别并不十分清楚。本文旨在阐明数字化、信息化和智能化的含义,探讨它们在实践中的应用,并梳理其异同之处。 一、数字化…

你不知道的AI绘画变现方式

🏆 文章目标:学习AI绘画变现方式 🍀 入门篇:你不知道的AI绘画变现方式 ✅ 创作者:熊猫Jay ✨ 个人公众号: 熊猫Jay字节之旅 (文末有链接) 🍁 展望:若本篇讲解内容帮助到您,请帮忙点个…

【科研必备】生态系统碳循环模型CENTURY建模方法

CENTURY模型,主要基于过程的陆地生态系统生物地球化学循环模型。主要用于模拟不同土壤-植被系统间C、N、P和S的长期动态。根据土壤有机质的分解速率,CENTURY模型将土壤总有机碳(TOC)分成了三个碳库,即活性、慢性和惰性…

Rest API 开发分享

概述 REST 从资源的角度来观察整个网络,分布在各处的资源由URI确定,而客户端的应用通过URI来获取资源的表示方式。获得这些表徵致使这些应用程序转变了其状态。随着不断获取资源的表示方式,客户端应用不断地在转变着其状态,所谓表…

js获取本js文件名称

使用 script 标签的 src 属性: 如果您的 JavaScript 文件是通过 script 标签引入的,您可以使用以下方法来获取当前脚本的文件名: var scripts document.getElementsByTagName(script); var currentScript scripts[scripts.length - 1]; va…

CMU 15-445 -- Multi-Version Concurrency Control - 16

CMU 15-445 -- Multi-Version Concurrency Control - 16 引言MVCCExample #1Example #2小结 Design DecisionsConcurrency Control ProtocolVersion StorageAppend-Only StorageTime-Travel StorageDelta Storage Garbage CollectionTuple-Level GCTransaction-Level GC Index …

Android编译报错-keystore2

vendor/mediatek/proprietary/trustzone/trustkernel/source/build/k39tv1_64_bsp_k419/array.c vendor/mediatek/proprietary/trustzone/trustkernel/source/build/k39tv1_64_bsp_k419/cert.dat 这个两个文件和厂家名称等配置信息有关。

STM32CubeMX配置STM32G031多通道ADC采集(HAL库开发)

时钟配置HSI主频配置64M 勾选打开8个通道的ADC 使能连续转换模式 配置好串口,选择异步模式配置好需要的开发环境并获取代码 修改main.c 串口重定向 #include "stdio.h" int fputc(int ch, FILE *f) {HAL_UART_Transmit(&huart1, (uint8_t *)&ch…