时间:2021-05-23
存储过程,可以这样认为,将我们需要特殊处理的sql语句封装成函数,当需要的时候我们只需调用这个函数就可以实现我们想要的操作,这个过程我们可以称之为存储过程。当然了,真正存储过程的定义不是这样的。但是我们可以这样简单的去理解存储过程。
下面我们看一个简单的使用存储过程的例子。
首先我们新建一张表 proced:
create table proced( id int(5) primary key auto_increment, name varchar(50), type varchar(50));然后我们需要向这个表中插入10万条数据,这个时候我们需要借助存储过程来实现这一功能。
mysql> delimiter //mysql> create procedure adddata() -->begin -->declare n int default 0; -->while n<100000 -->do -->insert into proced(name,type) values(‘迹忆博客','onmpw'); -->set n = n+1; -->end while; -->end -->//mysql> delimiter ;mysql> call adddata();使用上述存储过程,我们就可以向proced表中插入10万条数据了。
借助上述小例子,我们来讲一下如何创建一个存储过程。
创建存储过程
首先我们来看一下创建存储过程的语法:
CREATE PROCEDURE procedure_name(IN/OUT/INOUT parameter TYPE)BEGIN procedure_bodyEND这个过程比较简单。
在上面的小例子中我们看到在创建存储过程之前使用了delimiter //;,创建完成之后又再次 使用了命令 delimiter ;。
delimiter 是界定符,我们知道,在mysql命令行客户端,是通过分号(;)来界定一个命令是否完成的。在存储过程中,我们会多次使用到分号,但是这并不代表命令的结束,所以说我们需要使用delimiter命令来改变这个界定符。
mysql> delimiter //; 改变界定符为 //mysql> delimiter ; 重新改变界定符为分号所以说我们如果使用mysql命令行创建存储过程的话,我们必须在创建存储过程之前使用上述命令改变界定符。
接下来我们看到procedure_name()中的IN/OUT/INOUT,这是代表什么意思呢?
一个IN类型的参数会传递一个值到存储哦过程中,也就是我们在编程语言中自定义函数的参数。如果参数前面没有指定是IN/OUT/INOUT,那默认会是IN,看下面的例子:
mysql>delimiter //mysql> create procedure in_proced(IN param VARCHAR(100)) -->begin -->insert into proced(name,type) values(param,'onmpw'); -->end -->//mysql>delimiter ;mysql> call in_proced(‘onmpw.com');这就是在参数前指定IN的含义。
下面我们看OUT,指定为OUT的参数将从存储过程中传递一个值给调用者,也就是说,OUT可以认为这个参数就是我们自定义函数中的返回值。
mysql> delimiter //mysql> create procedure out_proced(OUT param INT) -->begin -->select count(*) into param from proced; -->end -->//mysql>delimiter ;mysql> call out_proced(@a);mysql>select @a;+------+| @a |+------+| 3 |+------+最后就是INOUT,很明显INOUT指定的参数被调用者初始化,其值在存储过程中可以被修改,并且任何改变对于调用者来说都是可见的。
看下面的例子:
mysql> delimiter //mysql> create procedure inout_proced(INOUT param INT) --> begin --> select count(*) into param from proced where id>param; --> end -->//mysql>delimiter ;mysql>set @a = 3;mysql>call inout_proced(@a);mysql>select @a; 查看变量的值是否改变以上就是创建一个简单的存储过程的方式。
删除存储过程
删除存储过程的语法:
DROP PROCEDURE IF EXISTS procedure_name
下面是使用实例:
mysql>drop procedure if exists proced;
修改存储过程
存储过程的修改时不能改变存储过程内的sql语句的,只能改变其属性,其语法如下:
ALTER PROCEDURE proc_name [characteristic ...]characteristic: COMMENT 'string' | LANGUAGE SQL | { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA } | SQL SECURITY { DEFINER | INVOKER }总结:无论是删除存储过程还是修改存储过程,必须保证你要修改或者删除存储过程没有被其他存储过程使用,例如你有存储过程A,和存储过程B。A在B中被使用,如果我们想修改A或者删除A,必须确保B中不再使用A,否则如果我们删除A以后,再调用B的时候就会报错。
举个例子:
mysql>delimiter //mysql>create procedure A(IN pa1 INT,OUT pa2 INT) -->begin -->select count(*) into pa2 from proced where id>pa1; -->end -->//mysql>create procedure B(INOUT pa INT) -->begin -->declare v int; -->call A(pa,v); -->set pa = v; -->end -->//mysql>delimiter ;mysql>drop procedure A;mysql>set @a=5;mysql>call B(@a);ERROR 1305 (42000): PROCEDURE test.A does not exists以上就是对存储过程简单的介绍,希望对大家学习mysql存储过程有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
MySQL存储过程14.1.1创建存储过程MySQL中,创建存储过程的基本形式如下:CREATEPROCEDUREsp_name([proc_parameter
MySQL存储过程参数有三种类型:in、out、inout。它们各有什么作用和特点呢?一、MySQL存储过程参数(in)MySQL存储过程“in”参数:跟C语言
一、MySQL存储过程参数(in)MySQL存储过程“in”参数:跟C语言的函数参数的值传递类似,MySQL存储过程内部可能会修改此参数,但对in类型参数的修改
mysql在5.1之后增加了存储过程的功能,存储过程运行在mysql内部,语句都已经编译好了,速度比sql更快.存储过程与mysql相当于shell和linux
本文实例讲述了mysql存储过程原理与用法。分享给大家供大家参考,具体如下:本文内容:什么是存储过程存储过程的创建存储过程的使用查看存储过程修改存储过程删除存储