1. 变量作用域
    内部的变量在其作用域范围内享有更高的优先权,当执行到end。变量时,内部变量消失,此时已经在其作用域外,变量不再可见了,应为在存储过程外再也不能找到这个申明的变量,但是你可以通过out参数或者将其值指派给会话变量来保存其值。

    mysql > DELIMITER //
    mysql > CREATE PROCEDURE proc3()
    -> begin
    -> declare x1 varchar() default 'outer';
    -> begin
    -> declare x1 varchar() default 'inner';
    -> select x1;
    -> end;
    -> select x1;
    -> end;
    -> //
    mysql > DELIMITER ;
  2. 条件语句
    • if-then -else 语句

      mysql > DELIMITER //
      mysql > CREATE PROCEDURE proc2(IN parameter int)
      -> begin
      -> declare var int;
      -> set var=parameter+;
      -> if var= then
      -> insert into t values();
      -> end if;
      -> if parameter= then
      -> update t set s1=s1+;
      -> else
      -> update t set s1=s1+;
      -> end if;
      -> end;
      -> //
      mysql > DELIMITER ;
    • case 语句
      mysql > DELIMITER //
      mysql > CREATE PROCEDURE proc3 (in parameter int)
      -> begin
      -> declare var int;
      -> set var=parameter+;
      -> case var
      -> when then
      -> insert into t values();
      -> when then
      -> insert into t values();
      -> else
      -> insert into t values();
      -> end case;
      -> end;
      -> //
      mysql > DELIMITER ;
  3. 循环语句
    • while ···· end while 语句

      mysql > DELIMITER //
      mysql > CREATE PROCEDURE proc4()
      -> begin
      -> declare var int;
      -> set var=;
      -> while var< do
      -> insert into t values(var);
      -> set var=var+;
      -> end while;
      -> end;
      -> //
      mysql > DELIMITER ;
    • repeat···· end repeat 语句
      mysql > DELIMITER //
      mysql > CREATE PROCEDURE proc5 ()
      -> begin
      -> declare v int;
      -> set v=;
      -> repeat
      -> insert into t values(v);
      -> set v=v+;
      -> until v>=
      -> end repeat;
      -> end;
      -> //
      mysql > DELIMITER ;

      它在执行操作后检查结果,而while则是执行前进行检查。

    • loop ·····end loop 语句
      mysql > DELIMITER //
      mysql > CREATE PROCEDURE proc6 ()
      -> begin
      -> declare v int;
      -> set v=;
      -> LOOP_LABLE:loop
      -> insert into t values(v);
      -> set v=v+;
      -> if v >= then
      -> leave LOOP_LABLE;
      -> end if;
      -> end loop;
      -> end;
      -> //
      mysql > DELIMITER ;

      loop循环不需要初始条件,这点和while 循环相似,同时和repeat循环一样不需要结束条件, leave语句的意义是离开循环。

  4. LABLES 标识
    LABLES(例如 LOOP_LABLE:)可以用在begin repeat while 或者loop 语句前,语句标号只能在合法的语句前面使用。可以跳出循环,使运行指令达到复合语句的最后一步。
  5. ITERATE 迭代
    mysql > DELIMITER //
    mysql > CREATE PROCEDURE proc10 ()
    -> begin
    -> declare v int;
    -> set v=;
    -> LOOP_LABLE:loop
    -> if v= then
    -> set v=v+;
    -> ITERATE LOOP_LABLE;
    -> end if;
    -> insert into t values(v);
    -> set v=v+;
    -> if v>= then
    -> leave LOOP_LABLE;
    -> end if;
    -> end loop;
    -> end;
    -> //
    mysql > DELIMITER ;

    通过引用复合语句的标号,来从新开始复合语句

MySQL 存储过程控制语句的更多相关文章

  1. mysql存储过程详解

    mysql存储过程详解 1.      存储过程简介   我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的S ...

  2. mysql存储过程学习

    一.存储过程的创建 语法: CREATE PROCEDURE sp_name (参数)合法的SQL语句 mysql> delimiter // mysql> CREATE PROCEDUR ...

  3. mysql存储过程详细教程

    记录mysql存储过程中的关键语法:DELIMITER //  声明语句结束符,用于区分;CREATE PROCEDURE demo_in_parameter(IN p_in int)  声明存储过程 ...

  4. Mysql存储过程总结

    1.     关于MySQL的存储过程 存储过程是数据库存储的一个重要的功能,但是MySQL在5.0以前并不支持存储过程,这使得MySQL在应用上大打折扣.好在MySQL 5.0终于开始已经支持存储过 ...

  5. MySQL存储过程中的3种循环

    在MySQL存储过程的语句中有三个标准的循环方式:WHILE循环,LOOP循环以及REPEAT循环.还有一种非标准的循环方式:GOTO,不过这种循环方式最好别用,很容易引起程序的混乱,在这里就不错具体 ...

  6. mysql 存储过程详解 存储过程

    mysql存储过程详解 1.      存储过程简介         我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成 ...

  7. MySQL存储过程详解 mysql 存储过程

    原文地址:MySQL存储过程详解  mysql 存储过程作者:王者佳暮 mysql存储过程详解 1.     存储过程简介 我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储 ...

  8. MySQL存储过程学习笔记

    MySQL在5.0以前并不支持存储过程,这使得MySQL在应用上大打折扣.MySQL 5.0终于开始支持存储过程了. MySQL的关键字大小写通用.该学习笔记对关键字使用大写:变量名,表名使用小写. ...

  9. MySQL存储过程详解 mysql 存储过程(二)

    mysql存储过程详解 1.      存储过程简介 我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL ...

随机推荐

  1. 转 PresentViewController切换界面

    视图切换,没有NavigationController的情况下,一般会使用presentViewController来切换视图并携带切换时的动画, 其中切换方法如下: – presentViewCon ...

  2. 深入理解javascript原型和闭包(8)——简述【执行上下文】上

    什么是“执行上下文”(也叫做“执行上下文环境”)?暂且不下定义,先看一段代码: 第一句报错,a未定义,很正常.第二句.第三句输出都是undefined,说明浏览器在执行console.log(a)时, ...

  3. 如何在ASP.NET MVC和EF中使用AngularJS

    (此文章同时发表在本人微信公众号"dotNET每日精华文章",欢迎右边二维码来关注.) AngularJS作为一个越来越流行的前端框架,在使用ASP.NET MVC和实体框架开发W ...

  4. 什么叫session和cookie-及其设置

    http的无状态? 保持状态, 是指当程序关闭后重启, 上一次操作的历史还能继续, 保持的. 如word中的 "选项"设置. 如windows系统的设置等等. http的设计目的, ...

  5. github提交代码时,报permission denied publickey

    在像github提交代码时,报permission denied publickey. 查找了一下,可能是因为github的key失效了. 按照以下步骤,重新生成key. ssh-keygen 一路默 ...

  6. Hadoop概括——学习笔记<一>

    之前有幸在MOOC学院抽中小象学院hadoop体验课. 这是小象学院hadoop2.X概述第一章的笔记 第一章主要讲的是hadoop基础知识.老师讲的还是比较全面简单的,起码作为一个非专业码农以及数据 ...

  7. [Machine Learning & Algorithm] 决策树与迭代决策树(GBDT)

    谈完数据结构中的树(详情见参照之前博文<数据结构中各种树>),我们来谈一谈机器学习算法中的各种树形算法,包括ID3.C4.5.CART以及基于集成思想的树模型Random Forest和G ...

  8. PHP计算两个时间段是否有交集(边界重叠不算)

    优化前的版本: /** * PHP计算两个时间段是否有交集(边界重叠不算) * * @param string $beginTime1 开始时间1 * @param string $endTime1 ...

  9. CentOS 安装tomcat 7

    安装环境:CentOS-6.3 安装方式:源码安装 软件:apache-tomcat-7.0.29.tar.gz 下载地址:http://tomcat.apache.org/download-70.c ...

  10. Git 常用命令合集

    $ git init          建立git仓库(一般都是在github上新建好,直接克隆到本地) $ git clone **.git       克隆git仓库 $ git add -A   ...