MySql存储过程
创建存储过程语法:
DELIMITER//
create procedure 名称()
begin
–语句–
end;//
这是一个没有参数的存储过程,注意名称后面要写括号();
调用存储过程语法:call 名称();
存储过程参数
DELIMITER//
create procedure 名称( [IN|OUT|INOUT] 参数名称 参数数据类型)
begin
…
end;//
存储过程的参数类型有三个,IN ,OUT, INOUT。
默认是IN类型,表示该参数的值必须在调用存储过程时指定,一般只用于传入。
OUT:参数传出,不能用于传入参数值,在调用存储过程中可以改变其值,并可返回,调用存储过程时,out参数也必须指定,但必须是变量,不能是常量。
INOUT:传入同时传出,调用时可传入值,在调用过程中,可修改其值,同时也可返回值,注意,传入的只能是变量;
DELIMITER的作用
就是告诉mysql解释器,该段命令是否已经结束了,mysql是否可以执行了。
mysql的执行,它遇到分号就会自动执行,有时候,不想这么做,因为可能会写较多的sql语句,这个时候就可以用DELIMITER改变输入结束符,把DELMITER后面换成其他符号,//或者$$,这就相当于对整个小段语句做了一个简单封装,有的mysql可能因为版本原因创建存储过程需要用DELIMITER。
存储过程的变量
声明变量需要用declare关键字,一句declare只声明一个变量,变量必须先声明后使用;
变量的数据类型和长度与mysql的sql数据类型保持一致;
返回变量可以使用select语句;
它的作用域在begin和end之内;
一个存储过程是一个可编程的函数,它在数据库中创建并保存。它可以有sql语句和一些特殊的控制语句组成。
数据库中的存储过程可以看做是对编程中面向对象方法的模拟。