大纲:

  1. 创建、删除、调用。
  2. 声明变量、变量赋值、存储过程的入参
  3. 声明游标
  4. 声明异常处理器
  5. 判断
  6. 循环
  7. 使用心得
  8. mybatis调用存储过程

一、创建、删除、调用

  • 创建

    1. DELIMITER $$ #修改分隔符
    2. CREATE PROCEDURE test(IN pname VARCHAR(50)) #括号里是入参。
    3. BEGIN
    4. select pname; #存储过程中的语句用;结尾
    5. END$$ #存储过程本身用修改后的分隔符$$结尾
    6. DELIMITER ; ##还原分隔符

    begin、end之间是存储的执行的代码块。

   tips:mysql不支持匿名块(没有create procedure,直接写begin、end之间的内容),因此msql的代码块只能放在存储过程,自定义函数,触发器中。

  • 删除

    1. DROP PROCEDURE IF EXISTS test; #存储过程

    和表一样建立前确保数据库中没有同名存储过程。

  • 调用
    1. CALL test('xx');

    调用用call命令、这里参数传一个字符串进去、调用后显示xx。

二、声明变量、变量赋值、存储过程的入参

  • declare声明变量
  • set是直接赋值(可以用 '=' 号赋值,也可以用 ':=' 赋值,本文例子中都是用 '=' 赋值的。但之后的学习中发现用这种 ':=' 方式赋值更规范一些。)
  • select是将查询的结果进行赋值
    1. DROP PROCEDURE IF EXISTS test;
    2. DELIMITER $$
    3. CREATE PROCEDURE test(IN pname VARCHAR(50))
    4. BEGIN
    5. DECLARE prefix VARCHAR(20); #声明变量
    6. set prefix = 'nihao:'; #select 'nihenhao:' into prefix; 赋值
    7. select concat(prefix,pname); #concat函数:拼接2个字符串
    8. END$$
    9. DELIMITER ;
    10. CALL test('xx');:赋值方式有2种、根据需求选择。
  • 创建存储过程的时候已经提到了,存储过程可以有入参IN,也可以有出参OUT,还可以有出入参INOUT。IN类型只能作为传入参数使用,OUT只能作为传出参数使用,只有INOUT既可以传入存储过程又能传出来。
    1. drop PROCEDURE test;
    2. DELIMITER $$
    3. CREATE PROCEDURE test( IN people VARCHAR(8), OUT name VARCHAR(8),INOUT age INT )
    4. BEGIN
    5. IF people = 'man'
    6. THEN SET name := 'xiaoming';
    7. SET age :=age+1;
    8. ELSE SET name := 'xiaohong';
    9. SET age :=age+10;
    10. END IF;
    11. END $$
    12.  
    13. set @people = 'man'; #@var_name这样的写法是声明一个用户变量,只有在本次连接的客户端中有效。这里声明了3个变量people、name、age
    14. set @name = null;
    15. set @age = 6;
    16. call test(@people,@name,@age);
    17. SELECT @people,@name,@age from dual; #结果:man xiaoming 7

三、声明游标

  • 准备一个测试表

    1. TRUNCATE names;
    2. create table names
    3. (
    4. name VARCHAR(20),
    5. age int
    6. );
    7. INSERT into names VALUES ('lby',45);
    8. INSERT into names VALUES ('lala',23);
  • 游标可以理解为是一个带指针的结果集。
    1. DROP PROCEDURE IF EXISTS test;
    2. DELIMITER $$
    3. CREATE PROCEDURE test()
    4. BEGIN
    5. DECLARE name VARCHAR(20);
    6. DECLARE age int;
    7. DECLARE temp VARCHAR(50);
    8. DECLARE c1 CURSOR FOR select * from names; #声明游标
    9. OPEN c1; #使用游标前打开游标
    10. FETCH c1 INTO name,age; #将游标中的第一行依次付给name,age(name=lby,age=45)。tips:游标列数和变量数要相同。
    11. set temp = CONCAT(name,age);
    12. FETCH c1 INTO name,age; #第一次fetch后指针下移动,赋值第二行给name,age(name=lala,age=23)。
    13. CLOSE c1; #使用游标后关闭游标
    14. set temp = CONCAT(temp,CONCAT(name,age));
    15. SELECT temp from dual; #lby45lala23
    16. END$$
    17. DELIMITER ;
    18. CALL test();

四、声明异常处理器

  • 当sql执行时报错时会报出相应的sqlstate,根据不同的sqlstate我们可以给出不同的处理。--附一个sqlstate的详解:blog.csdn.net/u014653854/article/details/78986780
  • 处理器有2种:exit、continue。
    1. TRUNCATE names; #清空names表使fetch报错SQLSTATE''
    2. DROP PROCEDURE IF EXISTS test;
    3. DELIMITER $$
    4. CREATE PROCEDURE test()
    5. BEGIN
    6. declare age int default 0 ;
    7. declare name VARCHAR(20) default 0 ;
    8. declare flag int default 0;
    9. DECLARE c1 CURSOR FOR select * from names;
    10. declare CONTINUE HANDLER FOR SQLSTATE '' SET flag = 111; # continue handler 检测报错为02000的时候 将flag设为111,存储过程继续执行,如果换为exit handler在行为完处理语句set flag=111后直接退出存储过程。
    11. OPEN c1;
    12. FETCH c1 into name,age; #当执行这句时会报错sqlstate:02000 ,continue handler触发set flag= 111,继续执行后面的代码。
    13. CLOSE c1;
    14. select flag; #111
    15. END$$
    16. DELIMITER ;
    17. CALL ifpay_ccpay.test();

五、判断

  • if判断

    1. DROP PROCEDURE IF EXISTS test;
    2. DELIMITER $$
    3. CREATE PROCEDURE test(in age int)
    4. BEGIN
    5. declare flag VARCHAR(20);
    6. IF age = 1 THEN SET flag = '一';
    7. ELSEIF age = 2 THEN SET flag = '二';
    8. ELSE SET flag = 'I DONT KNOW';
    9. END IF; #结束标志
    10. select flag; #二
    11. END$$
    12. DELIMITER ;
    13. CALL ifpay_ccpay.test(2);

六、循环

循环有三种

  • while循环

    1. DROP PROCEDURE IF EXISTS test;
    2. DELIMITER $$
    3. CREATE PROCEDURE test()
    4. BEGIN
    5. DECLARE age int DEFAULT 0;
    6. mywhile:
    7. WHILE age < 5 #条件,
    8. DO
    9. set age = age+1; #do与endwhile之间是循环内容
    10. END WHILE ;
    11. SELECT age; #5
    12. END$$
    13. DELIMITER ;
    14. CALL test();
  • repeat循环
    1. DROP PROCEDURE IF EXISTS test;
    2. DELIMITER $$
    3. CREATE PROCEDURE test()
    4. BEGIN
    5. DECLARE age int DEFAULT 0;
    6. mywhile:
    7. repeat
    8. set age = age+1; #循环体
    9. UNTIL age>3 END REPEAT ; #条件
    10. SELECT age; #4
    11. END$$
    12. DELIMITER ;
    13. CALL test();
  • loop循环
    1. DROP PROCEDURE IF EXISTS test;
    2. DELIMITER $$
    3. CREATE PROCEDURE test()
    4. myproc: #存储过程的label
    5. BEGIN
    6. DECLARE age int DEFAULT 0;
    7. DECLARE count int DEFAULT 10;
    8. myloop: #loop的label
    9. LOOP
    10. set age = age +1;
    11. IF age < 5 then
    12. ITERATE myloop; #忽略后面代码继续执行。(continue)
    13. END IF;
    14. set count = count - 1;
    15. SELECT 'haha';
    16. LEAVE myloop; #离开循环。(break) leave也可直接用于存储过程本身myproc,如果这里换成myproc,则显示haha
    17. END LOOP;
    18. SELECT age,count; #5 9
    19. END$$
    20. DELIMITER ;
    21. CALL test();

   代码中有3个概念:label、iterate、leave

   label:名称标签,while、repeat、loop循环或者 存储过程本身begin关键字前面都可以加一个名称标签。  

   iterate:用于循环、继续当前循环,相当于java循环中的continue。

   leave:1.用于循环、离开当前循环,相当于java循环中的break。

        2.也可用于存过过程本身,直接离开存过过程。

循环小结:1.while repeat区别在于:while 先判断循环条件再循环,repeat 线循环后判断。

     2.loop没有结束条件,需要手动退出。

     3.iterate、leave也可以用于while、repeat。

七、使用心得

  1. 存储过程中慎用delete语句。
  2. 存储过程适合一些有规律的数据操作,比如根据一些业务规则初始化一些数据。
  3. 尽量不要用它代替简单的业务sql,因为存储过程的维护、迁移、易读性都不如直接写在代码中好。

八、mybatis调用存储过程

调用方式参考我另一篇文章:mybatis调用存储过程

mysql 存储过程(代码块)的更多相关文章

  1. 写一个MySql存储过程实现房贷等额本息还款计算(另外附javascript代码)

    写一个MySql存储过程实现房贷等额本息还款计算 MySql存储过程代码如下: DROP procedure IF EXISTS `calc_equal_interest_proc`; DELIMIT ...

  2. Mysql基础代码(不断完善中)

    Mysql基础代码,不断完善中~ /* 启动MySQL */ net start mysql /* 连接与断开服务器 */ mysql -h 地址 -P 端口 -u 用户名 -p 密码 /* 跳过权限 ...

  3. mysql存储过程和存储函数

    mysql存储过程和存储函数 存数函数代码示例: DROP PROCEDURE IF EXISTS calc_ci_day_suc_rate; delimiter // CREATE FUNCTION ...

  4. MYSQL存储过程、游标、触发器

    MySQL5 中添加了存储过程的支持. 大多数SQL语句都是针对一个或多个表的单条语句.并非所有的操作都怎么简单.经常会有一个完整的操作需要多条才能完成  存储过程简单来说,就是为以后的使用而保存的一 ...

  5. Mysql存储过程调用

    mysql存储过程实例教程 发布时间:2014-04-09编辑:JB01 这篇文章主要介绍了mysql存储过程的使用方法,mysql存储过程实例教程,有需要的朋友参考下.   1.1create  p ...

  6. mysql存储过程之异常处理篇

    mysql存储过程也提供了对异常处理的功能:通过定义HANDLER来完成异常声明的实现 语法如下: DECLARE handler_type HANDLER FOR condition_value[, ...

  7. 《MySQL 存储过程编程》-读书笔记

    本书结构: 第一部分:存储编程基础 第1章:存储过程程序基础 第2章:MySQL存储编程指南 第3章:语言基础 第4章:语句块 第5章:在存储程序中使用SQL 第一章:MySQL存储程序介绍 存储程序 ...

  8. MySQL存储过程(一)

    1.1 CREATE  PROCEDURE (创建) CREATE PROCEDURE存储过程名 (参数列表) BEGIN SQL语句代码块 END 注意: 由括号包围的参数列必须总是存在.如果没有参 ...

  9. MySQL存储过程(转载)

    转自:http://www.blogjava.net/sxyx2008/archive/2009/11/24/303497.html 1.1         CREATE  PROCEDURE  (创 ...

随机推荐

  1. SimpleFactoryPattern(23种设计模式之一)

    设计模式六大原则(1):单一职责原则 设计模式六大原则(2):里氏替换原则 设计模式六大原则(3):依赖倒置原则 设计模式六大原则(4):接口隔离原则 设计模式六大原则(5):迪米特法则 设计模式六大 ...

  2. cakephp静态资源404

    location ~ /\.(css|js|woff|ttf|gif|jpg|jpeg|png|bmp|swf) { rewrite ^/$/(.*)$ /$/app/webroot/$ last; ...

  3. DWR原理探秘

    DWR原理探秘 DWR(Direct Web Remoting)远程Web命令;是一个用于改善web页面与Java类交互的远程服务器端Ajax开源框架,可以帮助开发人员开发包含AJAX技术的网站.它可 ...

  4. 《Maven实战》笔记-2-坐标和依赖

    一.依赖范围 Maven在编译项目主代码的时候,需要使用一套classpath——编译classpath: 在编译和执行测试的时候,使用另一套classpath——测试classpath: 实际运行M ...

  5. 用C#截取指定长度的中英文混合字符串

    很早以前写过一篇文章(用C#截取指定长度的中英文混合字符串),但是对性能没有测试,有人说我写的这个方法性能有问题,后来想,可能真会有BT之需求要求传入一个几万K甚至几M体积的字符串进来,那将会影响正则 ...

  6. C# 重写WndProc 拦截 发送 系统消息 + windows消息常量值

    接收拦截+发送消息 对于处理所有消息.net 提供了wndproc进行重写 WndProc(ref Message m)protected override void WndProc(ref Mess ...

  7. HTTP状态码了解

    1xx   - - 消息 2xx   - - 成功 3xx   - - 重定向 4xx   - - 请求错误 5xx   - - 服务器错误 1xx-信息提示 这些状态代码表示临时的响应.客户端在收到 ...

  8. 爬取腾讯课堂IT-互联网分类的的课程信息存入csv文件

    标签(空格分隔): python from urllib.request import urlopen from bs4 import BeautifulSoup #获取IT-互联网分类每页的课程的链 ...

  9. C# 服务器端控件

    服务器端控件和客户端控件的比较? 区别:服务器端控件都会有个runat="Server"属性,这样才能够在后台对其进行设置修改,也就是在cs代码里面能对其修改设置.你做下测试 你放 ...

  10. web安全-密码安全

    web安全-密码安全 1.密码的作用 2.储存 3.传输 4.替代方案 5.生物特征密码 (指纹 人脸) 6.密码单向变换彩虹表 组合 密码变换次数越多越安全 加密成本几乎不变(生成密码速度慢一点) ...