Mysql 存储过程(变量、定义条件、处理程序、光标、流程控制构造)
最近由于有同事编写了存储函数,需要进行验证,但是对存储过程一直不是很了解,所以抽时间了解了一下存储过程的基本语法。本篇文章主要包括介绍了存储过程的5个小语法:declare语句的变量、定义条件、处理程序、光标、流程控制构造。在找了很久的资料后,其实发现最实在的资料就是官方的参考手册。我参考的是MySQL5.1参考手册官方简体中文版.chm。
存储过程:为以后的使用而保存的一条或多条Mysql语句的集合。
DECLARE 语句:不同项目局域到一个子程序:局部变量、条件、处理程序、光标。DECLARE仅被用在BEGIN..END复合语句里,且必须在复合语句的开头,在其他任何语句之前。
1、存储程序中的变量:DECLARE局部变量、变量SET语句、SELECT...INTO语句
1.1 DECLARE局部变量语法: DECLARE var_name[,....] type [DEFAULT value]
这个语句给变量提供一个默认值,请包含一个default子句,值可以被指定为一个表达式,不需要为一个常数。
如果没有default子句,初始值为NULL.
局部变量的作用范围在它被声明的BEGIN...END块内。
1.2 变量SET语句语法:SET var_name = expr [, var_name = expr] ....
1.3 SELECT...INTO语句语法:SELECT col_name[,....] INTO var_name[,...] table_expr
这个select语法把选定的列直接存储到变量。
比如:select id,data into x,y from test.t1 limit 1
存储程序中的变量最终转化为一张图,如果这张表看懂了,基本不用看上面的文字,如图:
2、条件和处理程序:DECLARE 条件、DECLARE处理程序
2.1 DECLARE条件
DECLARE条件语法:DECLARE condition_name CONDITION FOR condition_value
Condition_value:
SQLSTATE [VALUE] sqlstate_value | mysql_error_code
这个语句指定需要特殊处理的条件,它将一个名字和指定的错误条件关联起来,随后会用在declare handler语句中。
2.2 DECLARE处理程序
DECLARE处理程序:DECLARE handler_type HANDLER FOR condition_value[,...] sp_statement
这个语句指定每个可以处理一个或多个条件的处理程序。如果产生一个或多个条件,指定的语句被执行。
Handler_type包含:CONTINUE | EXIT | UNDO
——对于CONTINUE 处理程序,当前子程序的执行在执行处理程序语句之后继续,即遇到错误不处理,继续执行
——对于EXIT 处理程序,当前BEGIN...END符合语句的执行被终止,即遇到错误立即退出。
——UNDO处理程序类型语句还不被支持,即遇到错误立马回退。
Condition_value包含:SQLSTATE [VALUE] sqlstate_value
|condition_name | SQLWARNING | NOT FOUND | SQLEXCEPTION | mysql_error_code
这个语句指定每个可以处理一个或多个条件的处理程序。如果产生一个或多个条件,指定的语句被执行。
——SQLWARNING是对所有以01开头的SQLSTATE代码的速记
——NOT FOUND 是对所有以02开头的SQLSTATE代码的速记
——SQLEXCEPTION是对所有没有被SQLWARNING或NOT FOUND捕获的SQLSTATE代码的速记
参考博文: https://blog.csdn.net/mytt_10566/article/details/80555250
2.3 光标(游标)
光标:内存中的一块区域,存放的是select的结果。
光标在存储程序和函数内被支持。
光标必须在声明处理程序之前被声明,并且变量和条件必须在声明光标或处理程序之前被声明。
声明光标:DECLARE cursor_name CURSOR FOR select_statement
这个语句声明一个光标,也可以在子程序中定义多个光标,但是一个块中的每一个光标必须有唯一的名字。
Select语句不能有into语句。
光标open语句:open cursor_name
这个语句打开先前声明的光标。
光标fetch语句:FETCH cursor_name INTO var_name [, var_name] ...
这个语句用指定的打开光标读取下一行(如果有下一行的话),并且前进光标指针。
光标close语句:CLOSE cursor_name
这个语句关闭先前打开的光标,如果未被明确地关闭,关闭在它被声明的复合语句的末尾被关闭。
2.4 流程控制构造
IF条件语句:
IF search_condition THEN statement_list
[ELSEIF search_condition THEN statement_list] ...
[ELSE statement_list]
END IF
IF实现了一个基本的条件构造,如果search_condition求值为真,相应的SQL列表被执行。如果没有search_condition匹配,在ELSE子句里的语句列表被执行。Statement_list可以包括一个或多个语句。
CASE条件语句:
CASE case_value
WHEN when_value THEN statement_list
[WHEN when_value THEN statement_list] ...
[ELSE statement_list]
END CASE OR: CASE
WHEN search_condition THEN statement_list
[WHEN search_condition THEN statement_list] ...
[ELSE statement_list]
END CASE
存储程序的CASE语句实现一个复杂的条件构造。如果search_condition求值为真,相应的SQL被执行。如果没有搜索条件匹配,在ELSE子句里的语句被执行。
LOOP循环语句:
[begin_label:] LOOP
statement_list
END LOOP [end_label]
LOOP允许某特定语句或语句群的重复执行,实现一个简单的循环构造。在循环内的语句一直重复直循环被退出,退出通常伴随着一个LEAVE语句。
LEAVE退出语句:LEAVE label
这个语句被用来退出任何被标注的流程控制构造。它和BEGIN...END或循环一起被使用。
ITEARTE再次循环语句:ITEARTE label
ITEARTE 只可以出现在LOOP、REPEAT和WHILE语句内。ITERATE意思为:再次循环。
REPEAT 循环语句:
[begin_label:] REPEAT
statement_list
UNTIL search_condition
END REPEAT [end_label]
REPEAT语句内的语句或语句群被重复,直至search_condition 为真。
REPEAT 语句可以被标注。 除非begin_label也存在,end_label才能被用,如果两者都存在,它们必须是一样的。
WHILE 循环语句:
[begin_label:] WHILE search_condition DO
statement_list
END WHILE [end_label]
WHILE语句内的语句或语句群被重复,直至search_condition 为真。
WHILE语句可以被标注。 除非begin_label也存在,end_label才能被用,如果两者都存在,它们必须是一样的。
IF、CASE、LOOP、WHILE、ITERATE、LEAVE构造被完全实现。
这些构造可能每个包含要么一个单独语句,要么是使用BEGIN...END复合语句的一块语句。
anyway,流程控制构造说了那么多,其实最重要的就是包含条件语句、循环语句、退出语句。如果大家不想看那么多文字,只需要看懂下面的图,就能很清晰的了解流程控制构造的一些基本内容。
条件语句IF和CASE语句的流程图:
循环语句、退出语句示例图:
Mysql 存储过程(变量、定义条件、处理程序、光标、流程控制构造)的更多相关文章
- MYSQL进阶学习笔记四:MySQL存储过程之定义条件,处理过程及存储过程的管理!(视频序号:进阶_11,12)
知识点五:MySQL存储过程之定义条件和处理过程及存储过程的管理(11,12) 定义条件和处理: 条件的定义和处理可以用来定义在处理过程中遇到的问题时相应的处理步骤. DECLARE CONTINUE ...
- shell(shell变量、条件表达式、流程控制)
本章内容: 变量 运算 if语句 for语句 while语句 break.continue 实例 shell变量 1.shell变量简介 变量是任何一种编程语言都必不可少的组成部分,变量用来存放各种数 ...
- MySQL知识补充(表字段操作、视图、触发器、事物、存储过程、内置函数、流程控制、索引、慢查询)
今日内容概要 表字段操作补充(掌握) 视图(了解) 触发器(了解) 事务(掌握) 存储过程(了解) 内置函数(了解) 流程控制(了解) 索引(熟悉) 内容详细 1.表字段操作补充 # 1.添加表字段 ...
- MySQL 之视图、 触发器、事务、存储过程、内置函数、流程控制、索引
本文内容: 视图 触发器 事务 存储过程 内置函数 流程控制 索引 ------------------------------------------------------------------ ...
- MySQL视图、触发器、事务、存储过程、内置函数、流程控制、索引
一.视图 1.什么是视图 视图就是通过查询得到一张虚拟表,然后保存下来,下次直接使用即可 2.为什么要用视图 如果频繁使用一张虚拟表,可以不用重复查询 3.如何使用视图 create view tea ...
- mysql存储过程变量的拼接
存储过程变量的拼接 有时候我们需要模糊查询,但是同时我们又要 在模糊查询的时候使用变量,我们又想在变量的后面拼接一个%去匹配模糊查询 那么就会用到 concat函数 示例如下: www. ...
- mysql 存储过程变量及循环的使用
1.用游标循环 BEGIN -- 定义变量 -- 定义done DECLARE done INT; -- 定义 ammeter_id_bl DECLARE ammeter_id_bl DOUBLE; ...
- MySQL--视图、触发器、事务、存储过程、内置函数、流程控制、索引
视图 触发器 事务 存储过程 内置函数 流程控制 索引 视图 1.什么是视图 视图就是通过查询得到一张虚拟表,然后保存下来,下次直接使用即可 2.为什么要用视图 如果要频繁使用一张虚拟表,可以不用重复 ...
- [Shell]条件判断与流程控制:if, case, for, while, until
---------------------------------------------------------------------------------------------------- ...
随机推荐
- gcc 执行c++报错
D:\cpp>g++ hello.cc Info: resolving std::cout by linking to __imp___ZSt4cout (auto-import) c:/min ...
- 全文思维导图------redis设计与实现
- 七:Redis的持久化
1.RDB(Redis DataBase) 1.1 定义:在指定的时间间隔内将内存中的数据集快照写入磁盘,也就是行话讲的snapshot快照,他恢复时是将快照文件直接读到内存里 是什么:Redis会单 ...
- stm32串口的配置方案
最近老板要我去做控制方面的内容,所以买了一块正点原子的开发板,现在是研究了一下usart.c,函数的代码如下: void USART1_IRQHandler(void) { u8 Res; #ifde ...
- 利用CSS3实现div页面淡入动画特效
利用CSS3实现页面淡入动画特效 摘要 利用CSS3动画属性"@keyframes "可实现一些动态特效,具体语法和参数可以网上自行学习.这篇文章主要是实践应用一下这个动画属性 ...
- SSL加密原理
对称加密算法 对称加密算法,同一个密钥可以同时用作信息的加密和解密,这种加密方法称为对称加密,也称为单密钥加密. 非对称加密算法 非对称加密算法(RSA)是内容加密的一类算法,它有两个秘钥:公钥与私钥 ...
- kali 系列学习06 - 攻击之密码破解
参考书 <kali linux渗透测试技术详解> 清华大学出版社 2015 杨波 一.medusa使用 原理:并行登陆破解 1.只输入单个命令,是查看帮助 root@kali:/tool ...
- 通过Folx的排序功能来设置下载任务的优先级
当我们使用Folx进行多任务下载时,突然遇到要下载一个紧急文件的情况,该如何让这个紧急文件的下载任务排在优先的位置?当然,用户也可以先暂停所有的下载任务,仅开启紧急文件的下载任务. 但这种方式需要用户 ...
- FL Studio钢琴卷轴之工具菜单的Riff命令
鼠标左键点击FL Studio钢琴卷轴窗口中的"工具"命令,我们就可以打开快捷工具菜单.快捷菜单中包含了用于音符编辑的各种工具.按照该菜单的顺序,我们先来看一下什么是Riff器命令 ...
- 对于this和当前线程的一些理解
在学习这个InheritableThreadLocal类的时候,我对于有个地方一直没有理解,我发现了盲点. 1 private void init(ThreadGroup g, Runnable ta ...