首页 > 数据库 >[MySQL]流程控制语句

[MySQL]流程控制语句

时间:2024-01-27 09:34:09浏览次数:34  
标签:语句 deptId end name 流程 MySQL sum select

【版权声明】未经博主同意,谢绝转载!(请尊重原创,博主保留追究权)
https://www.cnblogs.com/cnb-yuchen/p/17991087
出自【进步*于辰的博客

参考笔记三,P32.5。

目录
用于测试的数据表:
在这里插入图片描述

1、选择语句

需求:输入员工名emp_name,获取部门id对应的部门名称。

1.1 if

格式:

if 条件1 then 语句1 elseif 条件2 then 语句2 else 语句3 end if;

示例:

CREATE DEFINER=`root`@`localhost` PROCEDURE `TestProcess`(IN `emp_name` varchar(20))
BEGIN
	declare deptId int default 0;
	select dept_id into deptId from emps where name = emp_name;

	IF deptId = 1 THEN
		select '开发部' from dual;
	ELSEif deptId = 2 THEN
		select '策划部' from dual;
	else
		select '其他部门' from dual;
	END IF;
END

测试:
在这里插入图片描述
测试结果:
在这里插入图片描述

1.2 case

1.2.1 形式一

格式:

case when 条件1 then 语句1 when 条件2 then 语句2 else 语句3 end case;

示例:

CREATE DEFINER=`root`@`localhost` PROCEDURE `TestProcess`(IN `emp_name` varchar(20))
BEGIN
	declare deptId int default 0;
	select dept_id into deptId from emps where name = emp_name;

	case
	when deptId = 1 THEN
		select '开发部' from dual;
	when deptId = 2 THEN
		select '策划部' from dual;
	else
		select '其他部门' from dual;
	END case;
END

1.2.2 形式二

格式:

case 参数 when 值1 then 语句1 when 值2 then 语句2 else 语句3 end case;

示例:

CREATE DEFINER=`root`@`localhost` PROCEDURE `TestProcess`(IN `emp_name` varchar(20))
BEGIN
	declare deptId int default 0;
	select dept_id into deptId from emps where name = emp_name;

	case deptId
	when 1 THEN
		select '开发部' from dual;
	when 2 THEN
		select '策划部' from dual;
	else
		select '其他部门' from dual;
	END case;
END

2、循环语句

需求:输入一个数n,计算1 ~ n的总和。

2.1 while

格式:

while 结束条件 do 语句 end while;

示例:

CREATE DEFINER=`root`@`localhost` PROCEDURE `TestProcess`(IN n int)
BEGIN
	declare sum int default 0;
	
	while n > 0
	do
		set sum = sum + n;
		set n = n - 1;
	end while;
	
	select sum;
END

测试:
在这里插入图片描述
测试结果:
在这里插入图片描述

2.2 repeat

格式:

repeat 语句 until 结束条件 end repeat;

示例:

CREATE DEFINER=`root`@`localhost` PROCEDURE `TestProcess`(IN n int)
BEGIN
	declare sum int default 0;
	
	REPEAT
		set sum = sum + n;
		set n = n - 1;
	UNTIL n < 0 end REPEAT;
	
	select sum;
END

2.3 loop

格式:

xx:loop if 条件1 then [leave xx;] end if; if 条件2 then [iterate xx;] end if; end loop xx
// leave类似break(必须有,作为循环终止);iterate类似continue。

示例:

CREATE DEFINER=`root`@`localhost` PROCEDURE `TestProcess`(IN n int)
BEGIN
	declare sum int default 0;
	
	calSum: loop
		if n < 0 then
			leave calSum;// leave 类似于 break
		end if;
		
		set n = n - 1;
		
		if n = 5 then
			iterate calSum;// iterate 类似于 continue
		end if;
		
		set sum = sum + n;
	end loop calSum;
	
	select sum;
END

n < 0时,循环结束;当n = 5时,跳过此次循环。当然,这个例子的测试结果不是55。

最后

本文中的例子是为了方便大家了解MySQL流程控制语句的格式及使用而简单举例的,不一定有实用性。

如果大家想要了解存储过程,可查阅博文《[MySQL]关于存储过程的理解与简述》。

本文完结。

标签:语句,deptId,end,name,流程,MySQL,sum,select
From: https://www.cnblogs.com/cnb-yuchen/p/17991087

相关文章

  • 企业计算机服务器中了mallox勒索病毒怎么办,mallox勒索病毒解密流程
    随着网络技术的不断发展,网络安全威胁无处不在,这给企业的正常生产生活带来了极大影响,因此,做好企业的运维工作至关重要。近日,云天数据恢复中心接到北京某连锁品牌酒店的求助,企业的计算机服务器中了mallox勒索病毒导致企业系统内的重要数据被加密,无法正常使用,严重影响了企业正常运行,经......
  • 计算机服务器中了halo勒索病毒怎么办,halo勒索病毒解密处理流程
    计算机技术的发展与应用为企业的生产生活提供了坚实基础,但同时也为网络安全威胁制造了有利条件。近期,网络上的勒索病毒非常嚣张,给企业的计算机服务器带来严重威胁。近日,云天数据恢复中心接到山东某制造公司的求助,企业的计算机服务器被halo勒索病毒攻击,导致系统所有数据被加密无法使......
  • Odoo 15开发手册第八章 业务逻辑 - 业务流程的支持
    在前面的文章中,我们学习了如何使用模型层构建应用数据结构,然后使用ORMAPI和记录集查看和操作这些数据。本章中,我们把前面所学串到一起实现一些应用中常见的逻辑模式。我们会学习一起触发业务逻辑的方式,以及支撑这些方式的一些常见模式。我们还将学习一些重要的开发技巧,如打日志、......
  • logstash实现Mysql(Tidb)数据到Elasticsearch数据迁移(增量同步)
    1、下载Logstash和Elasticsearch,需要版本一致,本次使用版本均为7.8.0版本[root@zjkdata]#llelasticsearch-7.8.0-linux-x86_64.tar.gzlogstash-7.8.0.tar.gz-rw-r--r--.1rootroot31911256112月2815:39elasticsearch-7.8.0-linux-x86_64.tar.gz-rw-r--r--.1root......
  • C++教程——初识c++(循环,判断,跳转语句)
    在程序设计中,循环语句的使用十分重要,不同的需求需要用到不同的循环语句,对各种循环语句的熟练使用是学好程序设计的关键。接下来就来介绍循环语句及其使用。对于while循环来说,注意判断条件的使用,do...while语句要注意,它至少会执行一次do中的代码块,这是需要注意到的,对于for循环来说,括......
  • 在springboot中controller控制器的crud语句@RequestBody遗落的报错
    在进行java练习的过程中,对一个单链表进行增删改查时发现了如下错误:对编译器的控制台进行检查之后,发现了报错语句如下:2024-01-2619:43:52.551ERROR18544---[p-nio-80-exec-5]o.a.c.c.C.[.[.[/].[dispatcherServlet]:Servlet.service()forservlet[dispatcherSe......
  • MySQL--约束
    概述概念:约束作用于表中字段上的规则,用于限制存储再表中的数据。作用:保证数据库中的数据的正确、有效性和完整性。分类:约束描述关键字非空约束限制该字段的数据不能为nullNOTNULL唯一约束保证该字段的所有数据都是唯一UNIQUE主键约束主键是一行......
  • Oracle 数据库常用操作语句
    一、Oracle数据库操作1、创建数据库   createdatabase databasename2、删除数据库    dropdatabase dbname3、备份数据库完全备份    exp demo/demo@orcl buffer=1024 file=d:\back.dmp full=y   demo:用户名、密码   buffer: 缓存大......
  • 一个用来将数字转换为英文的MySql函数
    网上很容易找到SQLServer等其它数据库转英文数字的函数,但是MySql我没有找到,故写了下来:DELIMITER$$CREATEFUNCTIONConvertThreeDigitInteger2EnWords(numStrchar(3))RETURNSvarchar(50)DETERMINISTICBEGIN /*此函数接受一个形容'010'的用3位字符表示的数字,......
  • MySQL数据库精选(从入门使用到底层结构)
    基本使用MySQL通用语法及分类DDL:数据定义语言,用来定义数据库对象(数据库、表、字段)DML:数据操作语言,用来对数据库表中的数据进行增删改DQL:数据查询语言,用来查询数据库中表的记录DCL:数据控制语言,用来创建数据库用户、控制数据库的控制权限DDL(数据定义语言)数据定义......