mysql 开发基础系列18 存储过程和函数(下)
1. 光标的使用(游标)
在存储过程和函数中可以使用光标对结果集进行循环的处理,光标使用包括光标的声明,open ,fetch,close。
下面在存储过程中使用一个光标, 这个举例中光标里的逻辑不重要, 重点在于如何使用光标:
SELECT city_id FROM test.city

DELIMITER $$
CREATE PROCEDURE proc_demo_cursor()
BEGIN
-- 定义变量,获取光标中的数据
DECLARE city_id_staff SMALLINT DEFAULT 0; -- 声明光标
DECLARE cur_city CURSOR FOR SELECT city_id FROM test.city; -- 定义条件 没有找到数据时退出光标 NOT FOUND CLOSE cur_city
DECLARE EXIT HANDLER FOR NOT FOUND CLOSE cur_city; SET @result=0; -- 打开光标
OPEN cur_city;
REPEAT
FETCH cur_city INTO city_id_staff;
IF city_id_staff < 10 THEN
SET @result=@result+1;
ELSE
SET @result=@result+2;
END IF;
UNTIL 0 END REPEAT; -- 关闭光标
CLOSE cur_city;
END $$
DELIMITER ; -- 调用
CALL proc_demo_cursor;
SELECT @result;

2. 流程控制
包括 if ,case, loop, leave, iterate, repeat, while 语句进行流程控制
2.1 IF 语句
-- 语法如下
IF search_condition THEN statement_list
[ELSE IF search_condition THEN statement_list] ...
[ELSE statement_list]
END IF
-- 举例
IF city_id_staff < 10 THEN
SET @result=@result+1;
ELSE
SET @result=@result+2;
END IF;
2.2 CASE 语句
-- 举例二种用法
CASE
WHEN i_staff_id = 2 THEN
SET @x1 = @x1 + d_amount;
ELSE
SET @x2 = @x2 + d_amount;
END CASE;
-- 或者:
CASE i_staff_id
WHEN 2 THEN
SET @x1 = @x1 + d_amount;
ELSE
SET @x2 = @x2 + d_amount;
END CASE;
2.3 loop 语句
loop 实现简单的循环,退出循环条件可以使用leave语句。
DELIMITER $$
CREATE PROCEDURE proc_demo_loop()
BEGIN
DECLARE increase INT DEFAULT 1;
SET @x=0;
ins: LOOP
SET increase=increase+1;
IF increase =100 THEN
SET @x=increase;
-- 退出
LEAVE ins;
END IF; END LOOP ins;
END $$
DELIMITER ;
-- 调用
CALL proc_demo_loop;
SELECT @x;

2.4 ITERATE语句
ITERATE该语句必须用在循环中,作用相当于for 中的continue, 跳过当前循环剩下的语句,直接进入下一轮循环。
DELIMITER $$
CREATE PROCEDURE proc_demo_iterate()
BEGIN
DECLARE increase INT DEFAULT 1;
SET @x=0;
ins: LOOP
SET increase=increase+1;
IF increase =100 THEN
-- 退出
LEAVE ins;
ELSEIF MOD(increase,2)=0 THEN
-- 返回
ITERATE ins;
END IF;
SET @x=@x+1;
END LOOP ins;
END $$
DELIMITER ;
-- 调用
CALL proc_demo_iterate;
SELECT @x;

2.5 repeat 语句
有条件的循环控制语句,当满足条件的时候退出循环,在上面的光标也是一种循环,使用repeat来退出光标,使用close来关闭光标。
-- 语法
[begin_label:] REPEAT
statement_list
UNTIL search_condition
END REPEAT [end_label] -- 举例(UNTIL 0 END REPEAT)退出 当search_condition为0时,使用END REPEAT退出
REPEAT
FETCH cur_city INTO city_id_staff;
IF city_id_staff < 10 THEN
SET @result=@result+1;
ELSE
SET @result=@result+2;
END IF;
UNTIL 0 END REPEAT;
2.6 while 语句
也是有条件的循环控制语句,当满足条件的时候退出循环。WHILE 循环和REPEAT 循环的区别在于:WHILE 是满足条件才执行循环,REPEAT 是满足条件退出循环;WHILE 在首次循环执行之前就判断条件,所以循环最少执行0 次,而REPEAT 是在首次执行循环之后才判断条件,所以循环最少执行1 次。 相当于开发语言的while(bool) 和do while(bool)。
DELIMITER $$
CREATE PROCEDURE proc_demo_while()
BEGIN
DECLARE increase INT DEFAULT 1;
SET @x=0;
WHILE increase<=10 DO
SET increase=increase+1;
SET @x=@x+increase;
END WHILE;
END $$
DELIMITER ; -- 调用
CALL proc_demo_while;
SELECT @x;

mysql 开发基础系列18 存储过程和函数(下)的更多相关文章
- mysql 开发基础系列17 存储过程和函数(上)
一. 概述 存储过程和函数是事先经过编译并存储在数据库中的一段sql语句集合,可以简化应用开发人员的很多工作,减少数据在数据库与应用服务器之间的传输,提高数据处理效率是有好处的.存储过程和函数的区别在 ...
- mysql 开发基础系列12 选择合适的数据类型(上)
一. char 与varchar比较 在上图的最后一行的值只适用在"非严格模式",关于严格模式后面讲到.在“开发基础系列4“ 中讲到CHAR 列删除了尾部的空格.由于char是固定 ...
- mysql 开发基础系列5 字符串函数
字符串函数 1. concat (s1,s2,...sn) 连接里面的参数成一个字符串(注意上面写错了函数名称) SELECT CONCAT('ddd','CCC'); 2. insert(str ...
- mysql 开发基础系列7 流程函数与其它函数
一.流程函数 -- 创建表来介绍 ,)); ,),(,), (,),(,),(,), (,NULL); SELECT * FROM salary 1. if(value,t,f) 超过2000的用h ...
- mysql 开发基础系列6 数值与日期函数
一. 数值函数 1. abs(x) 返回x的绝对值 SELECT ABS(-0.8),ABS(0.8); 2.ceil(x) 返回大于x的最大整数 SELECT CEIL(-0.8),CEIL(0. ...
- mysql 开发基础系列20 事务控制和锁定语句(上)
一.概述 在mysql 里不同存储引擎有不同的锁,默认情况下,表锁和行锁都是自动获得的,不需要额外的命令, 有的情况下,用户需要明确地进行锁表或者进行事务的控制,以便确保整个事务的完整性.这样就需要使 ...
- mysql 开发基础系列1 表查询操作
在安装完数据库后,不管是windows 还是linux平台, mysql的sql命令都大同小异,相关命令都是相同的,每个命令结束后 都以 ; 结尾, 注意在windows平台中表名是不区分大小写 ...
- mysql 开发基础系列22 SQL Model
一.概述 与其它数据库不同,mysql 可以运行不同的sql model 下, sql model 定义了mysql应用支持的sql语法,数据校验等,这样更容易在不同的环境中使用mysql. sql ...
- mysql 开发基础系列21 事务控制和锁定语句(下)
1. 隐含的执行unlock tables 如果在锁表期间,用start transaction命令来开始一个新事务,会造成一个隐含的unlock tables 被执行,如下所示: 会话1 会话2 ...
随机推荐
- RNQOJ PID28 / [Stupid]愚蠢的宠物
勉勉强强够着点并查集的边,题目吧他分类到并查集也无可厚非,这里与常规的并查集的区别在于要做一个mark数组进行一下标记,展开来说就是对于要查询的A,B,先对A进行处理,把A所有的前驱也就是双亲节点进行 ...
- 微信小程序开发之搞懂flex布局2——flex container
容器的概念,是用来包含其它容器(container)和项目(item). flex container——flex容器 A flexbox layout is defined using the fl ...
- nacos 使用记
本文记录SpringBoot和SpringCloud与Nacos作为配置中心的整合过程及问题 Nacos官方使用文档:https://nacos.io/zh-cn/docs/what-is-nacos ...
- Self Attention需要掌握的基本原理
字面意思理解,self attention就是计算句子中每个单词的重要程度. 1. Structure 通过流程图,我们可以看出,首先要对输入数据做Embedding 1. 在编码层,输入的word- ...
- 【js jQuery】map集合 循环迭代取值---以及 map、json对象、list、array循环迭代的方法和区别
后台给前台传来一个map @ResponseBody @RequestMapping(value = "getSys") public Map<Long,String> ...
- linux五种I/O模型
1.基本概念 1.1同步和异步 同步和异步关注的是消息通信机制 1.1.1同步 所谓同步,就是在发出一个调用时,在没有得到结果之前,调用就不返回,一直在等,但是一旦调用返回,就能得到返回值. 1.1. ...
- jQuery源码框架fn解读
(function( window, undefined ){ var jQuery = (function(){ var jQuery = function( selector, context ) ...
- js实现全屏和缩放
/** * @description 简单的浏览器检查结果. * `webkit` * webkit版本号,如果浏览器为非webkit内核,此属性为`undefined`. * `chrome` * ...
- 【转载】 .NET框架设计—常被忽视的C#设计技巧
阅读目录: 1.开篇介绍 2.尽量使用Lambda匿名函数调用代替反射调用(走进声明式设计) 3.被忽视的特性(Attribute)设计方式 4.扩展方法让你的对象如虎添翼(要学会使用扩展方法的设计思 ...
- STM32的SWD调试进不了main函数
玩了那么久STM32,还没有用SWD调试过程序(一直都是用printf调试程序),觉得有些落后了,于是开始搞起了SWD调试. 很快通过查阅资料,知道了keil里面的配置和ST-Link与STM32的连 ...