博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Mysql存储过程编写
阅读量:5948 次
发布时间:2019-06-19

本文共 1653 字,大约阅读时间需要 5 分钟。

Mysql存储过程编写

存储过程编写的模板:
Create PROCEDURE PROCEDUREName (IN para mint,……)
Begin
Declare varname type;
语句;
End;
以上就是存储过程的编写模板。
其中,type可以是表中的任意类型,比如:varchar,bigint,int,decimal,longtext等等类型。
游标的声明是:
Declare cursorName cursor from select语句。
Declare continue handler for not found set varName = 1;
varName在使用的时候,需要进行声明,这个是表明如果游标没有数据了,varName赋值为1时表示没有值。
Open cursorName;表示打开游标。
CLOSE cursorName;表示关闭游标。
FETCH cursorName into varlist;表示向游标中取出值。
If条件语句:
1、种情况
If 条件 then
满足条件时执行的语句
End if;
2、种情况
If 条件 then
满足条件的执行的语句
Else
不满足条件的执行的语句
End if;
循环语句:
Out_loop:LOOP

END LOOP out_loop;

这个是LOOP循环,其中out_loop表示的是LOOP的循环标签,类似于汇编的标签。
其中结束LOOP循环的语句是:
LEAVE out_loop;out_loop表示LOOPd的标签
例子:
create PROCEDURE selectExtratUnit()
BEGIN
DECLARE id BIGINT;
DECLARE na LONGTEXT;
DECLARE linkName LONGTEXT;
DECLARE notfound INT;
DECLARE cursor_avgScore CURSOR for select summary_id,text2 from edoc_summary_extend_send_sj where text2 is not null and text2 <> '';
DECLARE CONTINUE HANDLER FOR NOT FOUND SET notfound = 1;
OPEN cursor_avgScore;
out_loop:LOOP
if notfound = 1 THEN
LEAVE out_loop;
end if;
FETCH cursor_avgScore into id,na;
select group_concat(org_name) into linkName from trans_org_sj where org_id in (
SELECT SUBSTRING_INDEX(SUBSTRING_INDEX(na,'|',help_topic_id+1),'|',-1) AS num FROM mysql.help_topic WHERE help_topic_id < LENGTH(na)-LENGTH(REPLACE(na,"|",''))+1 );
INSERT into extrat_table(id,orgname) VALUES(id,linkName);
END LOOP out_loop;
CLOSE cursor_avgScore;
end;

注意:

在创建存储过程的时候,选用的用户端的不同,会导致存储过程在语法对的情况下,会有一些错误。最好使用Navicat和mysql自带的黑窗口。如果使用mysql自带的黑窗口,需要在编写存储过程的时候要使用DELIMITER //命令,执行完成后,在编写存储过程,编写完成后,使用//来表示命令的结束。

转载于:https://blog.51cto.com/xiaoshunzi/2397146

你可能感兴趣的文章
pxc群集搭建
查看>>
JS中加载cssText延时
查看>>
常用的脚本编程知识点
查看>>
计算机网络术语总结4
查看>>
新手小白 python之路 Day3 (string 常用方法)
查看>>
soapUI的简单使用(webservice接口功能测试)
查看>>
框架 Hibernate
查看>>
python-while循环
查看>>
手机端上传图片及java后台接收和ajaxForm提交
查看>>
【MSDN 目录】C#编程指南、C#教程、ASP.NET参考、ASP.NET 4、.NET Framework类库
查看>>
jquery 怎么触发select的change事件
查看>>
angularjs指令(二)
查看>>
<气场>读书笔记
查看>>
领域驱动设计,构建简单的新闻系统,20分钟够吗?
查看>>
web安全问题分析与防御总结
查看>>
React 组件通信之 React context
查看>>
Linux下通过配置Crontab实现进程守护
查看>>
ios 打包上传Appstore 时报的错误 90101 90149
查看>>
密码概述
查看>>
jQuery的技巧01
查看>>