Mysql存储过程

1.创建存储过程语法(格式)

DELIMITER $

CREATE PROCEDURE 存储过程名A(IN 传入参数名a INT,IN 传入参数名b VARCHAR(20),OUT 返回参数名c INT)

BEGIN

内容..........

END $

解析:

IN 代表传入的参数,定义传入参数名,并且后面跟上传入参数类型(INT,VARCHAR,DOUBLE,........)

OUT 代表存储过程执行完返回的数据,定义参数名,并且后面跟上参数类型(INT,VARCHAR,DOUBLE,........)

INOUT 代表既可以传入也可以返回 ,定义参数名,并且后面跟上参数类型(INT,VARCHAR,DOUBLE,........)

2.存储过程内具体语法与逻辑

A.定义变量语法:

DECLARE 变量名a 参数类型(INT,VARCHAR(20),BOOLEAN,........) [DEFAULT NULL];

注:可以在参数类型后面加 DEFAULT NULL; 来设置初始值。

B.变量赋值:

方式1(直接对变量进行赋值):

SET 定义的变量a = NEW();

方式2(sql查询的结果直接赋值给变量):

SELECT `student`.age INTO 定义的变量a FROM `student` WHERE...........

方式3(sql查询的结果直接赋值给多个变量):

SELECT `student`.name AS 定义的变量a,`student`.age AS 定义的变量b INTO 定义的变量a,定义的变量b FROM `student` ...............

c.逻辑判断:

#IF判断:

IF 条件语句(3>5) THEN

条件为TRUE时执行.........;

END IF;

#IF ELSE判断:

IF 条件(a>0) THEN

条件为(a>0)时执行........;

ELSE IF 条件(a<0) THEN

条件为(a<0)时执行.......;

ELSE

其它执行.......;

END IF;

D.游标,(LOOP)循环:

#例.单游标循环:create procedure my_procedure() -- 创建存储过程

begin -- 开始存储过程

declare my_id varchar(32); -- 自定义变量1

declare my_name varchar(50); -- 自定义变量2

DECLARE done INT DEFAULT FALSE; -- 自定义控制游标循环变量,默认false

DECLARE cur CURSOR FOR ( SELECT id, name FROM t_people ); -- 定义游标并输入结果集

DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE; -- 绑定控制变量到游标,游标循环结束自动转true

OPEN cur; -- 打开游标

posLoop: LOOP -- 开始循环体,myLoop为自定义循环名,结束循环时用到

FETCH cur into my_id, my_name; -- 将游标当前读取行的数据顺序赋予自定义变量12

IF done THEN -- 判断是否继续循环

LEAVE posLoop; -- 结束循环

END IF;

-- 自己要做的事情,在 sql 中直接使用自定义变量即可

UPDATE t_user SET c_name = my_name WHERE id = my_id and rtrim(ltrim(c_name)) = ''; -- 左右去空格

COMMIT; -- 提交事务

END LOOP posLoop; -- 结束自定义循环体

CLOSE cur; -- 关闭游标

END; -- 结束存储过程

#例.多游标循环:create procedure my_procedure() -- 创建存储过程begin -- 开始存储过程

declare my_id varchar(32); -- 自定义变量1

declare my_name varchar(50); -- 自定义变量2

DECLARE done INT DEFAULT FALSE; -- 自定义控制游标循环变量,默认false

DECLARE cur_1 CURSOR FOR ( SELECT id, name FROM t_people ); -- 定义游标并输入结果集

DECLARE cur_2 CURSOR FOR ( SELECT id_2,name_2 FROM t_people_2); --定义游标并输入结果集

DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE; -- 绑定控制变量到游标,游标循环结束自动转true

OPEN cur_1; -- 打开游标

posLoop: LOOP -- 开始循环体,myLoop为自定义循环名,结束循环时用到

FETCH cur_1 into my_id, my_name; -- 将游标当前读取行的数据顺序赋予自定义变量12

IF done THEN -- 判断是否继续循环

LEAVE posLoop; -- 结束循环

END IF;

-- 自己要做的事情,在 sql 中直接使用自定义变量即可

UPDATE ..........;  --自己要做的具体操作

END LOOP posLoop; -- 结束自定义循环体

CLOSE cur_1; -- 关闭游标

SET done = FALSE;  -- 因为当第一个游标遍历完后其值被handler设置为TRUE了,如果不用set把它设置为 FALSE ,那么第二个游标就不会遍历了。(最好是在每个打开游标的操作前都用该语句,以确保游标能真正遍历)

OPEN cur_2; -- 打开游标

posLoop_2: LOOP -- 开始循环体,myLoop为自定义循环名,结束循环时用到

FETCH cur_2 into my_id, my_name; -- 将游标当前读取行的数据顺序赋予自定义变量12

IF done THEN -- 判断是否继续循环

LEAVE posLoop_2; -- 结束循环

END IF;

-- 自己要做的事情,在 sql 中直接使用自定义变量即可

INSERT ..........;   --自己要做的具体操作

END LOOP posLoop_2; -- 结束自定义循环体

CLOSE cur_2; -- 关闭游标

END; -- 结束存储过程

3.存储过程的调用

#调用没有返回值的存储过程CALL 存储过程名(参数.....);

#调用有返回值的存储过程(获得返回值)

CALL 存储过程名(@aaa);

SELECT @aaa;

4.删除存储过程

DROP PROCEDURE 存储过程名;

5.注意事项

存储过程中的分号(;)很重要,尽量不要省略。

mysql中的逻辑类型如何定义_MYSQL存储过程即常用逻辑知识点总结相关推荐

  1. 数组在mysql中是什么类型_MySQL 中的数据类型介绍

    1.概述 要了解一个数据库,我们也必须了解其支持的数据类型. MySQL支持所有标准的SQL数据类型,主要分3类: 数值类型 字符串类型 时间日期类型 另一类是几何数据类型,用的不多,也没多介绍.  ...

  2. MySQL中的整数类型

    文章目录 1 MySQL中的整数类型 1.1 整数类型简介 1.2 整数类型的附带属性 1 MySQL中的整数类型 1.1 整数类型简介 整数类型是数据库中最基本的数据类型.标准SQL中支持INTEG ...

  3. mysql中的字段类型

    Mysql中的字段类型 MySQL支持大量的列类型,它可以被分为3类:数字类型.日期和时间类型以及字符串(字符)类型.本节首先给出可用类型的一个概述,并且总结每个列类型的存储需求,然后提供每个类中的类 ...

  4. MySQL时间戳和unix时间戳区别、MySQL中的时间类型

    文章目录 1 时间戳 1.1 unix时间戳(unix timestamp) 1.2 MySQL时间戳(timestamp) 2 MySQL中timestamp和datetime的不同点 3 MySQ ...

  5. MySQL中的列类型之字符串类型总结

    关联博文: MySQL中数值类型(列类型)与显示宽度 MySQL中的列类型之字符串类型总结 在SQL中,将字符串类型分为了六类:char,varchar,text,blob,enum和set. 类型 ...

  6. MySQL中的二进制类型

    文章目录 1 MySQL中的二进制类型 1.1 二进制类型概览 1.2 binary和varbinary类型 1.3 bit类型 1.4 blob类型 1.5 实战建议 1 MySQL中的二进制类型 ...

  7. MySQL中的Text类型

    文章目录 1 MySQL中的Text类型 1 MySQL中的Text类型 TEXT类型是一种特殊的字符串类型,包括TINYTEXT.TEXT.MEDIUMTEXT和LONGTEXT,其长度和存储空间的 ...

  8. MySQL中的浮点数类型和定点数类型

    文章目录 1 MySQL中的浮点数类型和定点数类型 1 MySQL中的浮点数类型和定点数类型 数据表中用浮点数类型和定点数类型来表示小数.浮点数类型包括单精度浮点数(FLOAT型)和双精度浮点数(DO ...

  9. 面试官问:mysql中时间日期类型和字符串类型的选择

    摘要:MySQL中有多种表示时间日期的数据类型,主要有YEAR.TIME.DATE.DATETIME.TIMESTAMP等 本文分享自华为云社区<一针见血,mysql中时间日期类型和字符串类型的 ...

最新文章

  1. 基于机器视觉的缺陷检测汽车零部件
  2. oschina添加ssh公钥一记
  3. 配置spring-mvc + simple-spring-memcached
  4. Python函数作为参数传递给函数
  5. shiro+php,一套基于SpringBoot+Vue+Shiro 前后端分离 开发的代码生成器
  6. 产品和运营的区别是什么?
  7. python中def fun()是什么意思_python里的def 方法中-代表什么意思?
  8. 操作系统的目标与作用
  9. js实现扫雷-算法分析
  10. 第四章 DirectX 渲染流水线(上)
  11. XPath解析中的 'Element a at 0x5308a80'是什么
  12. hive表信息查询、查看表结构、表操作等
  13. 在公共服务器上搭建python虚拟环境
  14. Ubuntu 群组管理
  15. java中short类型变量
  16. Pandas读取excel文件(pandas.read_excel)
  17. 【计算机科学】【2016.12】运动摄影测量中三维点云结构的比较与表征
  18. java游戏编程原理与实践教程_第18章青蛙过河游戏(Java游戏编程原理与实践教程课件).ppt...
  19. 如何为你的应用程序设置热键?
  20. ui字段和虚字段_绝无仅有!2019年最全的UI设计之输入字段剖析

热门文章

  1. 一个机械系毕业生的感言
  2. 计算卷积神经网络中参数量
  3. HTML用a标签出现404,404.html
  4. (web前端笔记)2020-12-23(http)
  5. linux fedora35安装kvm虚拟机命令整理
  6. Ubuntu18.04安装Scala
  7. 启动namenode报错:Journal Storage Directory /var/bigdata/hadoop/full/dfs/jn/dmgeo not formatted
  8. Jenkins安装目录说明
  9. mongodb 实现点赞功能
  10. Dubbo 融合 Nacos 成为注册中心