Mysql存储过程编写
admin
2023-04-17 12:01:18
0

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 //命令,执行完成后,在编写存储过程,编写完成后,使用//来表示命令的结束。

相关内容

热门资讯

我来教教您“新永和牛牛到底有挂... 网上科普关于“新永和牛牛有没有挂”话题很是火热,小编也是针对新永和牛牛作*弊开挂的方法以及开挂对应的...
玩家最新攻略“老铁联盟有挂吗?... 网上科普关于“老铁联盟有没有挂”话题很是火热,小编也是针对老铁联盟作*弊开挂的方法以及开挂对应的知识...
今日重磅消息“白金岛究竟有挂吗... 今日重磅消息“白金岛究竟有挂吗?”(必胜开挂神器)您好,白金岛这个游戏其实有挂的,确实是有挂的,需要...
南京剑指“全国软件产业智能化第... 12月27日,2025江苏省人工智能产业发展大会在南京举行。大会上,南京推动产业发展再“加码”,通过...
众星微系统取得基于FEC的自适... 国家知识产权局信息显示,无锡众星微系统技术有限公司取得一项名为“一种基于FEC的自适应的SerDes...
【今日要闻】“哥哥斗地主真的有... 家人们!今天小编来为大家解答哥哥斗地主透视挂怎么安装这个问题咨询软件客服徽9784099的挂在哪里买...
最新引进“毛豆大厅牛牛到底是不... 您好:毛豆大厅牛牛这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款...
重磅消息“哥哥打大A真的有挂吗... 您好:哥哥打大A这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款游...
终于懂了“闽乐茶楼开挂神器?”... 网上科普关于“闽乐茶楼有没有挂”话题很是火热,小编也是针对闽乐茶楼作*弊开挂的方法以及开挂对应的知识...
今日重大消息“创乐缘到底有挂吗... 有 亲,根据资深记者爆料创乐缘是可以开挂的,确实有挂(咨询软件无需打开直...