香港云主机最佳企业级服务商!

ADSL拨号VPS包含了中国大陆(联通,移动,电信,)

中国香港,国外拨号VPS。

当前位置:云主机 > MYSQL >

电信ADSL拨号VPS
联通ADSL拨号VPS
移动ADSL拨号VPS

mysql代码执行结构实例分析【顺序、分支、循环结构】


时间:2020-11-03 13:46 作者:admin


本文实例讲述了mysql/' target='_blank'>mysql代码执行结构。分享给大家供大家参考,具体如下:

本文内容:

什么是代码执行结构 顺序结构 分支结构 循环结构

首发日期:2018-04-18


什么是代码执行结构:

这里所说的代码执行结构就是多条sql语句的执行顺序。 代码执行结构主要用于触发器、存储过程和函数等存储多条sql语句中。

顺序结构:

顺序结构就是从上到下依次执行sql语句 一般默认情况下都是顺序结构

分支结构:

分支结构的执行是依据一定的条件选择执行路径,它会依据我们给定的条件来选择执行那些sql语句 MySQL中分支结构只有if-else: 语法:
if 条件 then sql语句[elseif 条件 then sql语句][else sql语句]end if;
示例:
-- create table pass(id int primary key auto_increment,name varchar(15),score int );create table unpass(id int primary key auto_increment,name varchar(15),score int);-- 使用存储过程来create procedure myif(in name varchar(15),in score int)begin if score >=60 then  insert into pass(name,score) values(name,score); else  insert into unpass(name,score) values(name,score); end if;end;-- 调用,并查看结果call myif("lilei",61);call myif("hanmeimei",95);select * from pass;select * from unpass;call myif("tuhao",59);select * from unpass;
if中的条件基本可以参照select语句的while子句的条件。什么in\not in \= \!= 等都可以用。
create procedure myif3(in a char(1))begin if a in('a','b') then  select 1; else   select 2; end if;end;call myif3('a');call myif3('b');call myif3('c');

补充:

理论上,如果做出判断不符合,然而又不想继续执行下去的时候,应该执行返回(比如C语言的return来中断函数运行),但mysql中并没有对应的中断机制,所以需要我们主动中断(中断的方法有很多种,比如执行一条符合语法但无法运行的语句)【这种场景比如有:判断一名学生是否存在,不存在就不执行任何操作,所以应该执行一条无法成功运行的语句来报错返回。】 事实上,还存在一种分支结构:case when 【好像好多书都没怎么讲到,所以这里不讲述。有兴趣的可以自行百度。】

循环结构:

循环结构是指在程序中需要反复执行某个功能而设置的一种程序结构。mysql中循环结构用于循环多次运行同一sql语句。 mysql中的循环结构有loop结构、while结构、repeat结构,这里只讲述while结构,有兴趣了解其他的可以自行百度。 语法:
while 条件 do sql语句end while;
学过其他语言的可能会了解到循环结构中有continue(提前结束此次循环)和break(跳出整个循环) 在mysql的循环结构中,使用leave来代替break,使用iterate来代替continue,但它们的使用语法是:leave\iterate 循环名,所以如何定义循环名呢?
循环名:while 条件 do sql语句; leave\iterate 循环名;end while;
示例:
-- 无意义的一个例子,仅作演示create table whilenum(id int);-- 自带条件的create procedure mywhile()begin declare num int; set num=10; c1:while num>0 do   insert into whilenum values(num);   set num=num-1;  end while;end;-- 以传入参数作为条件的create procedure mywhile2(in num int)begin c1:while num>0 do   insert into whilenum values(num);   set num=num-1;  end while;end;-- 带中断的create procedure mywhile3(in num int)begin c1:while num>0 do   if num%2=0 then    set num=num-1;    iterate c1;   end if;   insert into whilenum values(num);   set num=num-1;  end while;end;

更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL查询技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》、《MySQL数据库锁相关技巧汇总》及《MySQL常用函数大汇总》

希望本文所述对大家MySQL数据库计有所帮助。

(责任编辑:admin)






帮助中心
会员注册
找回密码
新闻中心
快捷通道
域名登录面板
虚机登录面板
云主机登录面板
关于我们
关于我们
联系我们
联系方式

售前咨询:17830004266(重庆移动)

企业QQ:383546523

《中华人民共和国工业和信息化部》 编号:ICP备00012341号

Copyright © 2002 -2018 香港云主机 版权所有
声明:香港云主机品牌标志、品牌吉祥物均已注册商标,版权所有,窃用必究

云官方微信

在线客服

  • 企业QQ: 点击这里给我发消息
  • 技术支持:383546523

  • 公司总台电话:17830004266(重庆移动)
  • 售前咨询热线:17830004266(重庆移动)