mysql之流程控制
目录
- 分支结构
- 循环结构
分支结构:
1.if condition then [statement] elseif condition then [statement] else [statement] end if
实例:求两个数中的最大值,如果两个数据相等,则返回0,不相等,则返回最大值
delimiter // -- 把默认的结束符;替换成//
create function test_if(a int,b int) returns int
BEGIN
DECLARE max int DEFAULT 0;
-- 下面为分支结构
if a > b then
set max = a;
ELSEIF a<b then
set max = b;
ELSE
set max = 0;
end if;
return max;
end;
// -- 查询
select test_if(1,2)
2.case when condition then [statement] when condition then [staement] else [statement] end case
实例:求两个数中的最大值,如果两个数据相等,则返回0,不相等,则返回最大值
delimiter // -- 把默认的结束符;替换成
create function test_when(a int ,b int) -- 函数结构
RETURNS int -- 返回值类型
BEGIN -- 开始标签
DECLARE max int default 0; -- 定义内部变量表示最大值,默认为0
-- 下面为分支结构
CASE
WHEN a > b then
SET max = a;
WHEN a < b then
SET max = b;
ELSE
SET max = 0;
END CASE;
RETURN max;
END;
//
-- 查询
select test_when(1,3)
循环结构:
循环控制语句包括 while condtion do [statement] 、loop 、repeat [statemnet] until condtion,其中while、loop满足条件开始循环,至少循环0次;而repeat满足条件退出循环,至少循环1次。
1. while condtion do [statement]
实例:求和
delimiter // -- 把默认的结束符;替换成
-- 求数值a以内的数据之和
create function test_while(a int) -- 函数结构
returns int -- 返回值类型
begin
DECLARE sum int default 0; -- 和
DECLARE count int default 1;-- 循环次数变量
-- 下面是循环控制语句
la:while count <= a do
set sum = sum + count;
set count = count + 1;
end while la;
return sum;
end;
//
2.loop
实例:求和
delimiter // -- 把默认的结束符;替换成
create function demo_loop(a int) returns int
BEGIN
DECLARE s int DEFAULT 0;
DECLARE i int DEFAULT 1;
la:loop
IF i>a then
LEAVE la;
end if;
set s = s+i;
set i=i+1;
end loop la;
return s;
end;
//
--查询
select demo_loop(1)
3.repeat [statement] until condtion
实例:求和
delimiter // -- 把默认的结束符;替换成//
create function demo_repeat(a int) returns int
begin
DECLARE s int default 0;
DECLARE i int DEFAULT 1;
la:REPEAT
set s = s+i;
set i=i+1;
UNTIL i>a
end REPEAT la;
return s;
end;
//
--查询
select demo_repeat(10)
mysql之流程控制的更多相关文章
- MySQL数据库----流程控制
流程控制 1.条件语句 举例一 delimiter // CREATE PROCEDURE proc_if () BEGIN declare i int default 0; if i = 1 THE ...
- MySQL 存储过程 -流程控制的使用
#五.流程控制的使用 #1.IF 使用 create PROCEDURE iftest1() BEGIN DECLARE a int DEFAULT 10; -- IF (a>1 &&a ...
- MySql存储过程及MySql常用流程控制语法
/* 该代码是创建了一个名叫"p4"的存储过程并设置了s1,s2,s3两个int型一个varchar型参数,还可以是其他数据类型,内部创建了x1,x2两个变量 DELIMITER是 ...
- 【mysql的编程专题①】流程控制与其他语法
流程控制与内置函数,一般用在select的field字段上,或者用在函数,存储过程,触发器中; 如果用在select上就会随着query出来的row来隐式迭代; 注释与语句结束符 语句结束符 默认有两 ...
- MySQL自定义函数用法详解-复合结构自定义变量/流程控制
自定义函数 (user-defined function UDF)就是用一个象ABS() 或 CONCAT()这样的固有(内建)函数一样作用的新函数去扩展MySQL. 所以UDF是对MySQL功能的一 ...
- mysql 视图 触发器 事物 存储过程 函数 流程控制
1.视图 *** 视图是有一条sql语句的查询结果构成的虚拟表 其不是物理存在的 使用方式与普通表相同 视图的作用1.简化sql语句的编写 2.限制可以查看的数据 可以使用权限来完成 权限某一个库 的 ...
- 知识点:Mysql 基本用法之流程控制
流程控制 一. 条件语句 if 语句实例: delimiter // CREATE PROCEDURE proc_if () BEGIN declare i int default 0; if i = ...
- MySQL之视图、触发器、事务、存储、函数、流程控制
一.视图 视图就是一个虚拟表,我们把复杂的sql语句后看到的虚拟表封装起来,给他取个名字,当我们下次使用的时候,就不用再去写复杂的sql语句,直接调用封装后的视图名字,就可以得到我们想要的表,然后就可 ...
- MySQL之视图、触发器、事务、存储过程、函数 流程控制
MySQL之视图.触发器.事务.存储过程.函数 阅读目录 一 视图 二 触发器 三 事务 四 存储过程 五 函数 六 流程控制 MySQL这个软件想将数据处理的所有事情,能够在mysql这个层面上全部 ...
随机推荐
- POJ 1061 青蛙的约会(扩展GCD求模线性方程)
题目地址:POJ 1061 扩展GCD好难懂.. 看了半天.最终把证明什么的都看明确了. .推荐一篇博客吧(戳这里),讲的真心不错.. 直接上代码: #include <iostream> ...
- BZOJ 3550 ONTAK2010 Vacation 单纯形
题目大意:给定一个长度为3n的区间.要求选一些数,且随意一段长度为n的区间内最多选k个数.求选择数的和的最大值 单纯形直接搞 注意一个数仅仅能被选一次 因此要加上xi<=1这个约束条件 不明确3 ...
- JavaScript学习14:表单处理
什么是表单? 在HTML中,表单是由<form>元素来表示的.而在JavaScript中,表单相应的则是HTMLFormElement类型.HTMLFormElement继承了HTMLEl ...
- 使用scanf_s报错:0xC0000005: Access violation writing location 0x00000000
在vs2010中写了一行scanf("%s",name); 调式时 提示warning , 提示修改为scanf()使用可能会存在不安全,建议使用scanf_s() 但是我修改成s ...
- problem in Sourcetree
1.The date is commit date not the date of author 2.The log line is ordered by time, actually it sho ...
- python库学习笔记——爬虫常用的BeautifulSoup的介绍
1. 开启Beautiful Soup 之旅 在这里先分享官方文档链接,不过内容是有些多,也不够条理,在此本文章做一下整理方便大家参考. 官方文档 2. 创建 Beautiful Soup 对象 首先 ...
- debian webmin 安装
/******************************************************************** * debian webmin 安装 * 说明: * 在服务 ...
- MySql LOAD DATA 使用
load的语法 LOAD DATA [LOW_PRIORITY | CONCURRENT] [LOCAL] INFILE 'file_name.txt' [REPLACE | IGNORE] INTO ...
- Excel VBA 入门
一.文件格式 要使用VBA,excel文件必须保存为启用宏的工作簿,即xlsm格式. 二.启动VBA编辑器 打开工作簿后,要启动VBA编辑器,有两种方法,一是在工作表的名字上面点击右键,选择“查看代码 ...
- Application 效能分析有妙招 — 使用 perf 走天下(转载)
转载:http://tech.mozilla.com.tw/posts/1803/application-%E6%95%88%E8%83%BD%E5%88%86%E6%9E%90-%E4%BD%BF% ...