主页 > 知识库 > mysql代码执行结构实例分析【顺序、分支、循环结构】

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

热门标签:AI电销 网站排名优化 铁路电话系统 服务外包 百度竞价排名 Linux服务器 地方门户网站 呼叫中心市场需求

本文实例讲述了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数据库计有所帮助。

您可能感兴趣的文章:
  • MySQL语句执行顺序和编写顺序实例解析
  • 简单了解mysql语句书写和执行顺序
  • 简单了解MySQL SELECT执行顺序
  • 有关mysql中sql的执行顺序的小问题
  • SQL语句执行深入讲解(MySQL架构总览->查询执行流程->SQL解析顺序)
  • sql和MySQL的语句执行顺序分析
  • 浅谈mysql执行过程以及顺序

标签:兰州 崇左 黄山 衡水 湘潭 仙桃 湖南 铜川

巨人网络通讯声明:本文标题《mysql代码执行结构实例分析【顺序、分支、循环结构】》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266