`

MySql存储过程

    博客分类:
  • Sql
 
阅读更多

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存储过程是数据库管理系统中的一种重要功能,它允许开发者预编译一系列SQL语句并封装成一个可重复使用的单元,从而提高数据处理的效率和代码的复用性。本教程将深入探讨MySQL存储过程的创建、调用以及相关概念...

    MySQL存储过程的异常处理方法

    本实例展示了如何在MySQL存储过程中实现异常处理,以捕获并处理可能出现的错误。 首先,我们注意到在创建存储过程`myProc`时,使用了`delimiter $$`来改变MySQL客户端的语句分隔符,这是为了在存储过程中使用多个...

    mysql经典教程+mysql存储过程讲解

    本教程结合"mysql经典教程+mysql存储过程讲解"的主题,将深入探讨MySQL的基础知识以及核心特性——存储过程。 首先,我们需要理解什么是数据库。数据库是一个组织和存储数据的系统,允许用户以结构化方式访问和管理...

    mysql存储过程之返回多个值的方法示例

    本文实例讲述了mysql存储过程之返回多个值的方法。分享给大家供大家参考,具体如下: mysql存储函数只返回一个值。要开发返回多个值的存储过程,需要使用带有INOUT或OUT参数的存储过程。咱们先来看一个orders表它的...

    Mysql存储过程常用语句模板

    Mysql存储过程常用语句模板(含变量,if,三种循环等等) Mysql存储过程常用语句模板(含变量,if,三种循环等等) Mysql存储过程常用语句模板(含变量,if,三种循环等等) Mysql存储过程常用语句模板(含变量,if,三...

    Java实现调用MySQL存储过程详解

    总的来说,Java通过JDBC调用MySQL存储过程涉及到连接数据库、创建`CallableStatement`、执行存储过程和处理结果。这使得开发者能够在Java应用中灵活地利用数据库提供的强大功能,实现更高效的数据处理。

    MySQL存储过程学习

    MySQL存储过程是数据库管理系统中的一种重要功能,它允许开发者预编译一系列的SQL语句,形成一个可重复使用的代码块,以提高数据处理的效率和应用程序的性能。在这个"MySQL存储过程学习"的主题中,我们将深入探讨...

    MySQL存储过程编程.pdf

    MySQL 存储过程编程 MySQL 存储过程编程是指在 MySQL 数据库中使用存储过程来实现业务逻辑的编程技术。存储过程是一种可以在数据库中存储和执行的程序单元,它可以实现复杂的业务逻辑和数据处理操作。 在 MySQL ...

    MySQL 存储过程入门到精通

    MySQL存储过程是数据库管理系统中的一个重要特性,它允许程序员或数据库管理员预先定义一组SQL语句,形成一个可重用的逻辑单元。在这个“MySQL存储过程入门到精通”资料中,你将深入理解存储过程的原理、创建、调用...

    mysql存储过程实例

    MySQL 存储过程实例 MySQL 存储过程实例详细介绍了 MySQL 存储过程的开发步骤,本节将通过具体的实例讲解 PHP 是如何操纵 MySQL 存储过程的。 创建存储过程 存储过程的创建是 MySQL 存储过程的基础,MySQL 5.0 ...

    mysql存储过程调试工具

    MySQL存储过程是数据库管理系统中的一种重要功能,它允许开发者编写一系列复杂的SQL语句,并作为一个单元进行执行,提高代码复用性和效率。然而,与普通的编程语言一样,存储过程的调试同样至关重要,因为错误的存储...

    c++实现调mysql存储过程

    c++实现调mysql存储过程,实现存储过程的出参入参,可以支持查询多数据返回,还有存储过程的复杂数据的增删改等

    mysql 存储过程 实战

    ### MySQL存储过程实战知识点 #### 一、存储过程概述 MySQL 存储过程是一种预编译的 SQL 脚本,它可以包含复杂的逻辑控制结构、循环等操作,并且可以接受参数,执行完后还可以返回结果。存储过程可以提高数据处理...

    mysql存储过程实现分页

    ### MySQL存储过程实现分页 #### 背景与需求 在数据库操作中,分页是一种常见的需求,尤其是在处理大量数据时。通过分页技术,可以有效地减少每次查询的数据量,提高系统的响应速度和用户体验。MySQL作为一种广泛...

    MySQL存储过程编程教程.pdf

    MySQL存储过程编程是数据库应用开发中的一个重要环节,它可以帮助开发者将一系列的数据库操作封装起来,以提高程序的可维护性和运行效率。在MySQL 5.0及以上版本中,存储过程、函数和触发器的支持为数据库提供了更...

    MySQL存储过程系统学习资料

    MySQL存储过程是数据库管理系统中的一个重要概念,它是一组为了完成特定功能的SQL语句集,经编译后存储在MySQL服务器中,用户可以调用这个预编译的语句集来执行任务,而不是每次需要时都重新编写相同的SQL代码。...

    mysql存储过程、触发器.pdf

    MySQL 存储过程和触发器详解 MySQL 存储过程是指一组为了完成特定功能的 SQL 语句集合。存储过程的优点包括: 1. 封装性:存储过程可以将多个 SQL 语句封装在一起,方便调用和维护。 2. 可增强 SQL 语句的功能和...

Global site tag (gtag.js) - Google Analytics