1. 创建存储过程

1.1 无参数存储过程

CREATE PROCEDURE bruce_procedure ()

BEGIN

--1.声明变量

--2.执行业务逻辑

END

1.2 有参数的存储过程

CREATE PROCEDURE bruce_procedure (

IN in_exam_id INT,

in_student_types_id VARCHAR (100)

)

BEGIN

--1.声明变量

--2.执行业务逻辑

END

IN 表示输入参数

2. 调用存储过程

--无参调用

Call bruce_procedure();

--有参调用

Call bruce_procedure(1,’2,1’);

3. 删除存储过程

Drop procedure bruce_procedure;

4. 查看存储过程信息

1) show procedure status

显示数据库中所有存储的存储过程基本信息,包括所属数据库,存储过程名称,创建时间等

2) show create procedure sp_name

显示某一个存储过程的详细信息

5. 声明变量

CREATE PROCEDURE sc_st_group_courses_class_procedure (

IN in_exam_id INT,

in_student_types_id VARCHAR (100)

)

BEGIN

-- 组织课程组关系id

DECLARE v_group_courses_id INT;

-- 考试组织id

DECLARE v_exam_group_id INT;

END

1) 可以在存储过程全局范围内声明

2) 如果要在局部范围内声明,需重新定义begin end,并在begin和end之间声明变量

6. If

if stop = 1 then

leave cur_loop;

end if;

7. 循环

7.1 结构

cur_loop : loop

//业务逻辑

end loop //结束循环

7.2 跳出循环

leave cur_loop;

8. 游标

8.1 声明游标

CREATE PROCEDURE sc_st_group_courses_class_procedure() 

BEGIN DECLARE STOP INT DEFAULT 0;

-- 创建游标

DECLARE cur CURSOR FOR (

select

group_courses_id,

exam_group_id,

courses_id,

class_id

from sc_group_courses_view WHERE group_class='class' and exam_id = in_exam_id

);

-- 游标捕捉越界异常

DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET STOP = 1;

END

8.2 打开和关闭游标

打开游标:OPEN cur

关闭游标:CLOSE cur

8.3 遍历游标

CREATE PROCEDURE sc_st_group_courses_class_procedure()

BEGIN DECLARE STOP INT DEFAULT 0;

-- 创建游标

DECLARE cur CURSOR FOR (

select

group_courses_id,

exam_group_id,

courses_id,

class_id

from sc_group_courses_view WHERE group_class='class' and exam_id = in_exam_id

);

-- 游标捕捉越界异常

DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET STOP = 1;

-- 开启游标

OPEN cur;

-- 开始循环

cur_loop : loop

FETCH cur INTO

v_group_courses_id,

v_exam_group_id,

v_courses_id,

v_class_id

;

-- 判断游标溢出

if stop = 1 then

leave cur_loop;

end if;

-- 结束循环

END loop cur_loop;

-- 关闭游标

CLOSE cur;

END

9. 给变量赋值

DECLARE v_median_index int;

set v_median_index = v_class_count/2-1;

10. 查询并赋值给变量

select

max(sum_score),min(sum_score),avg(sum_score),STD(sum_score)

into

v_highest_score,

v_lowest_score,

v_average,

v_std

from a

;

11. 参考

http://www.ccvita.com/100.html

MySQL知识总结(三)存储过程的更多相关文章

  1. MySQL 系列(三)你不知道的 视图、触发器、存储过程、函数、事务、索引、语句

    第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 第三篇:MySQL 系列(三)你不知道的 视图.触发器.存储过程.函数 ...

  2. MySQL知识树-查询语句

    在日常的web应用开发过程中,一般会涉及到数据库方面的操作,其中查询又是占绝大部分的.我们不仅要会写查询,最好能系统的学习下与查询相关的知识点,这篇随笔我们就来一起看看MySQL查询知识相关的树是什么 ...

  3. qlserver、Mysql、Oracle三种数据库的优缺点总结

    这篇文章主要介绍了sqlserver.Mysql.Oracle三种数据库的优缺点总结,需要的朋友可以参考下   一.sqlserver优点:易用性.适合分布式组织的可伸缩性.用于决策支持的数据仓库功能 ...

  4. MySQL系列(三)---索引

    MySQL系列(三)---索引 前言:如果有疏忽或理解不当的地方,请指正. 目录 MySQL系列(一):基础知识大总结 MySQL系列(二):MySQL事务 MySQL系列(三):索引 什么是索引 如 ...

  5. python mysql 视图 触发器 事物 存储过程 用户授权 数据备份还原

    ###################总结########### 视图是一个虚拟表(非真实存在) 是跑在内存中的表,真实表是在硬盘上的表 使用视图我们可以把查询过程中的临时表摘出来,保存下来,用视图去 ...

  6. 知识点:Mysql 基本用法之存储过程

    存储过程 一. 介绍 存储过程包含了一系列可执行的sql语句,存储过程存放于MySQL中,通过调用它的名字可以执行其内部的一堆sql 使用存储过程的优点: 用于替代程序写的SQL语句,实现程序与sql ...

  7. MySQL(7)---存储过程

    Mysql(7)---存储过程 存储过程接下来会有三篇相关博客 第一篇存储过程常用语法. 第二篇存储过程中的游标. 第三篇单独讲一个实际开发过程中复杂的真实的案例. 一.概述 1.什么是存储过程 概述 ...

  8. Mysql系列(三)—— Mysql主从复制配置

    一.前言 主从复制是Mysql知识体系中非常重的要一个模块.学习主从复制和后续的读写分离是完善只是知识体系的重要环节.且主从复制读写分离的思想并不仅仅局限于Mysql,在很多存储系统中都有该方案,如: ...

  9. mysql创建定时执行存储过程任务

    sql语法很多,是一门完整语言.这里仅仅实现一个功能,不做深入研究. 目标:定时更新表或者清空表. 案例:曾经做过定时清空位置信息表的任务.(然而,当时并未考虑服务器挂掉后的情况) 本次测试:每5s更 ...

  10. mysql开发中使用存储过程

    在mysql开发中使用存储过程的理由: 当希望在不同的应用程序或平台上执行相同的函数,或者封装特定功能时,存储过程是非常有用的 mysql 执行语句是要先编译,然后再执行的.这样如果查询并发大的时候. ...

随机推荐

  1. Ionic3 UI组件之 ImageViewer

    组件特性: 轻触图片可全屏查看 手势上下滑动可关闭全屏查看 点击导航箭头可关闭视图 双击查看全图,并可放大 参考地址:https://github.com/Riron/ionic-img-viewer ...

  2. 域名(Domain Name)

    是由一串用点分隔的名字组成的Internet上某一台计算机或计算机组的名称,用于在数据传输时标识计算机的电子方位(有时也指地理位置,地理上的域名,指代有行政自主权的一个地方区域). 域名是一个IP地址 ...

  3. Bootstrap table 跨页全选

    此代码是针对于bootstrap table中分页的跨页全选. 以下是整个bootstrap的定义 <script type="text/javascript" src=&q ...

  4. CodeBlocks "no such file or directory" 错误解决方案(创建类找不到头文件)

    在CodeBlocks下,有时候需要自己定义类,当然就要添加相应的头文件,但添加进去的头文件明明包含在项目中了, 但编译时还是会报错:no such file or directory;这是为什么呢? ...

  5. C# 很少人知道的科技

    本文来告诉大家在C#很少有人会发现的科技.即使是工作了好多年的老司机也不一定会知道,如果觉得我在骗你,那么请看看下面 因为C#在微软的帮助,已经从原来很简单的,到现在的很好用.在10多年,很少人知道微 ...

  6. web前端开发教程系列-3 - 前端开发调试工具分享

    前言 一. Bug出现的原因 1. 主观原因或者是出现这么多浏览器的原因 2. 另外客观原因: 二. 调试工具 1. Firebug 2. Chrome 3. IE11 4. IETester 5. ...

  7. MySQL 批量删除相同前缀的表

    sql 命令批量生成drop命令 需要批量删除表,而MySQL又没有提供相关的功能:一般我们建表也都会使用相同前缀,那么,在不使用工具的情况下可以选择使用sql生成批量删除命令: 如删除以 " ...

  8. python 函数私有方法

    #coding:utf-8 class A(object): def _test1(self): print('this is _test1') def test2(self): print('thi ...

  9. Mac下 KGDB连接Linux

    kgdb按照资料说可以使用网络(kgdboe)和串口连接(kgdboc)等方式连接. 这里使用后者,资料比较多,下面是自己在Mac上进行配置连接的过程. 先说一下环境: 主机:Mac OSX 10.1 ...

  10. :after伪类+content内容生成经典应用举例——张鑫旭

    一.简单说说content内容生成 content内容生成就是通过content属性生成内容,content属性早在CSS2.1的时候就被引入了,可以使用:before以及:after伪元素生成内容. ...