1.1 CREATE PROCEDURE
Q创建)
CREATE PROCEDURE存储q程?/span> (参数列表) BEGIN SQL语句代码?/span> END |
注意Q?/span>
由括号包围的参数列必LL存在。如果没有参敎ͼ也该使用一个空参数?)。每个参数默认都是一个IN参数。要指定为其它参敎ͼ可在参数名之前用关键词 OUT或INOUT
?strong>mysql客户端定义存储过E的时候?/span>delimiter命o来把语句定界W从;变ؓ//?/span>
当?/span>delimiter命oӞ你应该避免用反斜杠(‘"’)字符Q因为那?/span>MySQL的{义字W?/span>
如:
mysql> delimiter // mysql> CREATE PROCEDURE simpleproc (OUT param1 INT) -> BEGIN -> SELECT COUNT(*) INTO param1 FROM t; -> END -> // Query OK, 0 rows affected (0.00 sec) |
1.2 ALTER PROCEDURE
Q修改)
ALTER PROCEDURE 存储q程?/span>SQL语句代码?/span> |
q个语句可以被用来改变一个存储程序的特征?/span>
1.3 DROP
PROCEDURE Q删除)
DROP PROCEDURE IF EXISTS存储q程?/span>
eg:DROP PROCEDURE IF EXISTS proc_employee (proc_employee 存储q程?/span>) |
q个语句被用来移除一个存储程序。不能在一个存储过E中删除另一个存储过E,只能调用另一个存储过E?/span>
1.4 SHOW CREATE
PROCEDUREQ类gSHOW CREATE TABLEQ查看一个已存在的存储过E)
SHOW CREATE PROCEDURE 存储q程?/span> |
1.5 SHOW PROCEDURE
STATUS Q列出所有的存储q程Q?/span>
1.6 CALL语句Q存储过E的调用Q?/span>
CALL语句调用一个先前用CREATE PROCEDURE创徏的程序?/span>
CALL语句可以用声明ؓOUT或的INOUT参数的参数给它的调用者传回倹{?/span>
存储q程名称后面必须加括P哪怕该存储q程没有参数传?/span>
1.7 BEGIN ...
ENDQ复合语句)
[begin_label:] BEGIN [statement_list] END [end_label] |
存储子程序可以?/span>BEGIN ... END复合语句来包含多个语句?/span>
statement_list 代表一个或多个语句的列表?/span>statement_list之内每个语句都必ȝ分号Q;Q来l尾?/span>
复合语句可以被标记。除?/span>begin_label存在,否则end_label不能被给?/span>,q且如果二者都存在,他们必须是同L?/span>
1.8 DECLARE语句Q用来声明局部变量)
DECLARE语句被用来把不同目局域到一个子E序Q局部变?/span>
DECLARE仅被用在BEGIN ... END复合语句里,q且必须在复合语句的开_在Q何其它语句之前?/span>
1.9 存储E序中的变量
1.1 DECLARE局部变?/span>
DECLARE var_name[,...] type [DEFAULT value] q个语句被用来声明局部变量?/span> 要给变量提供一个默认|请包含一?/span>DEFAULT子句?/span> 值可以被指定Z个表辑ּQ不需要ؓ一个常数?/span> 如果没有DEFAULT子句Q初始gؓNULL?/span> 局部变量的作用范围在它被声明的BEGIN ... END块内?/span> 它可以被用在嵌套的块中,除了那些用相同名字声明变量的块?/span> |
1.2 变量SET语句
SET var_name = expr [, var_name = expr] 在存储程序中?/span>SET语句是一?/span>SET语句的扩展版本?/span> 被参考变量可能是子程序内声明的变量,或者是全局服务器变量?/span> 在存储程序中?/span>SET语句作ؓ预先存在?/span>SET语法的一部分来实现。这允许SET a=x, b=y, ...q样的扩展语法?/span> 其中不同的变量类型(局域声明变量及全局和集体变量)可以被合v来?/span> q也允许把局部变量和一些只对系l变量有意义的选项合ƈh?/span> |
1.3 SELECT ... INTO语句
SELECT col_name[,...] INTO var_name[,...] table_expr q个SELECT语法把选定的列直接存储到变量?/span> 因此Q只有单一的行可以被取回?/span> SELECT id,data INTO x,y FROM test.t1 LIMIT 1; 注意Q用户变量名?/span>MySQL 5.1中是对大写不敏感的?/span> |
重要: SQL变量名不能和列名一栗如?/span>SELECT ... INTOq样?/span>SQL语句包含一个对列的参考,q包含一个与列相同名字的局部变量,MySQL当前把参考解释ؓ一个变量的名字?/span>
1.10 MySQL 存储q程参数cdQin、out、inoutQ?/span>
此小节内Ҏ自:
参见地址Q?/span>http://www.aygfsteel.com/nonels/archive/2009/04/22/233324.html
MySQL 存储q程参数Q?/span>inQ?/span>
MySQL 存储q程 “in” 参数Q跟 C 语言的函数参数的g递类| MySQL 存储q程内部可能会修Ҏ参数Q但?/span> in cd参数的修改,对调用者(callerQ来说是不可见的Q?/span>not visibleQ?/span> |
MySQL 存储q程参数Q?/span>outQ?/span>
MySQL 存储q程 “out” 参数Q从存储q程内部传值给调用者。在存储q程内部Q该参数初始gؓ nullQ无用者是否给存储q程参数讄?/span> |
MySQL 存储q程参数Q?/span>inoutQ?/span>
MySQL 存储q程 inout 参数?/span> out cMQ都可以从存储过E内部传值给调用者。不同的是:调用者还可以通过 inout 参数传递值给存储q程?/span> |
ȝ
如果仅仅x数据传给 MySQL 存储q程Q那׃?/span>“in” cd参数Q如果仅仅从 MySQL 存储q程q回|那就使用“out” cd参数Q如果需要把数据传给 MySQL 存储q程Q还要经q一些计后再传回给我们Q此Ӟ要?/span>“inout” cd参数?/span> |
1.11 例子Q?/span>
1.1 创徏存储q程
?/span>(输出参数)q回值的存储q程Q?/span>
--删除存储q程
DROP PROCEDURE IF EXISTS proc_employee_getCount
--创徏存储q程
CREATE PROCEDURE proc_employee_getCount(out n int)
BEGIN
SELECT COUNT(*) FROM employee ;
END
--MYSQL调用存储q程
CALL proc_employee_getCount(@n); |
带输入参数的存储q程Q?/span>
--删除存储q程
DROP PROCEDURE IF EXISTS proc_employee_findById;
--创徏存储q程
CREATE PROCEDURE proc_employee_findById(in n int)
BEGIN
SELECT * FROM employee where id=n;
END
--定义变量
SET @n=1;
--调用存储q程
CALL proc_employee_findById(@n); |
操作存储q程时应注意:
1. 删除存储q程时只需要指定存储过E名卛_Q不带括P
2. 创徏存储q程Ӟ不管该存储过E有无参敎ͼ都需要带括号Q?/span>
3. 在?/span>SET定义变量时应遵@SET的语法规则;
SET @变量?/span>=初始|
4. 在定义存储过E参数列表时Q应注意参数名与数据库中字段名区别开来,否则出现无法预期的l果
1.12 Java代码调用存储q程(JDBC)
相关APIQ?/span>java.sql.CallableStatement
使用?/span>java.sql.CallableStatement接口Q该接口专门用来调用存储q程;
该对象的获得依赖?/span>java.sql.Connection;
通过Connection实例?/span>prepareCall()Ҏq回CallableStatement对象
prepareCall()内部Z固定写法{call
存储q程?/span>(参数列表1,参数列表2)}可用?占位
eg:
connection.prepareCall("{call
proc_employee(?)}");
存储q程中参数处?/span>:
输入参数:通过java.sql.CallableStatement实例?/span>setXXX()Ҏ赋|用法{同?/span>java.sql.PreparedStatement
输出参数:通过java.sql.CallableStatement实例?/span>registerOutParameter(参数位置, 参数cd)Ҏ赋?/span>,其中参数cd主要使用java.sql.Types中定义的cd
Java代码调用?span style="color: red;">输入参数的存储过E?/span>
(Ҏ输入ID查询雇员信息)
publicvoid executeProcedure()
{
try {
/**
*callableStatementjava.sql.CallableStatement
*connectionjava.sql.Connection
*jdbc调用存储q程原型
*{call存储q程?/span>(参数列表1,参数列表2)}可用?代替
*/
callableStatement=connection.prepareCall("{call proc_employee_findById(?)}");
callableStatement.setInt(1, 1); //讄输入参数
resultSet=callableStatement.executeQuery();//执行存储q程
if(resultSet.next())
{
System.out.println(resultSet.getInt(1)+""t"+resultSet.getString(2));
}
} catch (SQLException e) {
e.printStackTrace();
}
} |
Java代码调用?span style="color: red;">输出参数的存储过E?/span>
(q回数据库中的记录数)
public void executeProcedure()
{
try {
/**
*callableStatementjava.sql.CallableStatement
*connectionjava.sql.Connection
*jdbc调用存储q程原型
*{call存储q程?/span>(参数列表1,参数列表2)}可用?代替
*/
callableStatement=connection.prepareCall("{call proc_employee_getCount(?)}");
//讄输出参数
callableStatement.registerOutParameter(1, Types.INTEGER);
//执行存储q程
resultSet=callableStatement.executeQuery();
if(resultSet.next())
{
System.out.println(resultSet.getInt(1));
}
} catch (SQLException e) {
e.printStackTrace();
}
} |

]]>