001、
查看存储过程
show procedure status
查看指定存储过程
show create procedure sp_name
show procedure status where db='数据库名';
调用存储过程
call sp_name()
删除存储过程
DROP PROCEDURE sp_set
002、
一.创建存储过程
1.基本语法:
create procedure sp_name()
begin
………
end
2.参数传递
二.调用存储过程
1.基本语法:call sp_name()
注意:存储过程名称后面必须加括号,哪怕该存储过程没有参数传递
三.删除存储过程
1.基本语法:
drop procedure sp_name
drop procedure if exists sp_name
2.注意事项
(1)不能在一个存储过程中删除另一个存储过程,只能调用另一个存储过程
四.区块,条件,循环
1.区块定义,常用
begin
……
end;
也可以给区块起别名,如:
lable:begin
………
end lable;
可以用leave lable;跳出区块,执行区块以后的代码
2.条件语句
if …… then ……
elseif …… then ……
end if;
3.循环语句
(1)while循环
[label:] WHILE …… DO
……
END WHILE [label] ;
(2)loop循环
[label:] LOOP
……
if …… then leave label ; //跳出循环
END LOOP [label];
(3)repeat until循环
[label:] REPEAT
……
UNTIL expression
END REPEAT [label] ;
003、
Strict Mode的描述:
根据 mysql5.0以上版本 strict mode (STRICT_TRANS_TABLES) 的限制:
1).不支持对not null字段插入null值
2).不支持对自增长字段插入''值,可插入null值
3).不支持 text 字段有默认值
005、
CREATE PROCEDURE dayrepeat() BEGIN SELECT a.IntersectionUnit as '城区', a.IntersectionName as '路口', a.SCar+a.MCar+a.BCar as '总流量' FROM allintersection a; END; call dayrepeat();
006、
CREATE PROCEDURE test1(out mi DECIMAL,out ma DECIMAL,out av DECIMAL) BEGIN SELECT min(allintersection.SCar) AS 'min' INTO mi FROM allintersection ; SELECT max(allintersection.SCar) AS 'max' INTO ma FROM allintersection ; SELECT avg(allintersection.SCar) AS 'avg' INTO av FROM allintersection ; END; CALL test1(@a,@b,@c); SELECT @a AS '最小值', @b AS '最大值', @c AS '平均值'
007、
DROP PROCEDURE isTotal; create procedure isTotal( in InName BLOB, OUT Total decimal ) begin select SUM(SCar+MCar+BCar) into Total from allintersection where allintersection.IntersectionName = InName ; end; call isTotal('德胜路东新口路',@total); select @total as ;
008、
DROP PROCEDURE IF EXISTS test2; CREATE PROCEDURE test2(IN con DOUBLE, OUT result DOUBLE) BEGIN DECLARE temp DOUBLE; IF con=1 THEN SET temp= con*1; ELSEIF con=2 THEN SET temp= con*2; ELSEIF con=3 THEN SET temp= con*3; ELSE SET temp= con*0; END IF; SET result= temp; END; CALL test2(4,@result); SELECT @result as '结果';
009、开启事务、异常处理
BEGIN declare exit Handler for SQLException begin set result = -1; rollback; end; START TRANSACTION; select count(*) into result from role_buffs where model_id = buffModelId and role_id = memberId and (nowTime - quit_time) < remain_time ; #检查是否有退出buff if result = 0 then insert into gang_member(member_id,member_gangID,member_post,add_date) values(memberId,gangID,post,now()); update game_role set gang_id = gangID where role_id = memberId; set result = 1; else set result = -2; end if; commit; END
相关推荐
本文实例讲述了mysql存储过程之返回多个值的方法。分享给大家供大家参考,具体如下: mysql存储函数只返回一个值。要开发返回多个值的存储过程,需要使用带有INOUT或OUT参数的存储过程。咱们先来看一个orders表它的...
Mysql存储过程常用语句模板(含变量,if,三种循环等等) Mysql存储过程常用语句模板(含变量,if,三种循环等等) Mysql存储过程常用语句模板(含变量,if,三种循环等等) Mysql存储过程常用语句模板(含变量,if,三...
mysql经典教程+mysql存储过程讲解 重点讲解Mysql的存储过程,触发器,游标的使用 对mysql不太熟的朋友可以好好学习。。。
c++实现调mysql存储过程,实现存储过程的出参入参,可以支持查询多数据返回,还有存储过程的复杂数据的增删改等
mysql存储过程实现分页 mysql存储过程实现分页 mysql存储过程实现分页 mysql存储过程实现分页
本文实例讲述了MySQL存储过程的异常处理方法。分享给大家供大家参考。具体如下: mysql> mysql> delimiter $$ mysql> mysql> CREATE PROCEDURE myProc -> (p_first_name VARCHAR(30), -> p_last_name VARCHAR(30)...
MySQL存储过程学习 MySQL存储过程 MySQL存储过程
mysql 存储过程 实战
mysql存储过程ppt
mysql获取两个时间相差年月日:使用mysql存储过程,实现计算两个时间的差值,并用年月日时分秒的格式输出,且从大到小为0时则不展示对应单位(如:相差1小时20秒 则展示'1时0分20秒')
mysql存储过程,存储函数练习,里面有详细代码,供大家参考
MySQL存储过程
MySQL存储过程编程 可以看看 数据库 存储过程
php中调用MySQL存储过程示例
MySQL存储过程,入门简单,循序渐进,很适合自学,很详尽,很好学。
mysql存储过程调试工具,可以设置断点,方便查看变量信息等。好用,简单
给了一个小的mysql 存储过程的例子。同时给出了一个在pb9中调用的例子.本例子是给出的mysql8.0的存储过程。对于5.7一下的现在odbc很难有支持
MySQL存储过程实例教程,MySQL存储过程实例教程
mysql存储过程实例详细介绍了mysql存储过程的开发步骤