我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL中如何使用存储过程

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL中如何使用存储过程

这篇文章将为大家详细讲解有关MySQL中如何使用存储过程,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

使用CallableStatements执行存储过程

mysql版本:5.0
Connector/J的版本:3.1.1以上(java.sql.CallableStatement接口已完全实现,除了getParameterMetaData()方法)
MySQL的存储过程语法在MySQL参考手册的"存储过程和函数"一章.
http://www.mysql.com/doc/en/Stored_Procedures.html
下面是一个存储过程,返回一个inOutParam增1后的值,以ResultSet形式传入一个字符串参数inputParam.
CREATE PROCEDURE demoSp(IN inputParam VARCHAR(255), INOUT inOutParam INT)
BEGIN
DECLARE z INT;
SET z = inOutParam + 1;
SET inOutParam = z;
SELECT inputParam;
SELECT CONCAT('zyxw', inputParam);
END

要通过connector/J使用demoSp这个存储过程,要经过几个步骤:
1.Connection.prepareCall()


  1. import java.sql.CallableStatement;

  2. ...

  3. //

  4. // Prepare a call to the stored procedure 'demoSp'

  5. // with two parameters

  6. //

  7. // Notice the use of JDBC-escape syntax ({call ...})

  8. //

  9. CallableStatement cStmt = conn.prepareCall("{call demoSp(?, ?)}");

  10. cStmt.setString(1, "abcdefg");


Connection.prepareCall()方法非常消耗资源,因为jdbc驱动通过元数据(metadata)的获取支持输出参数.出于执行效率的考虑,应该尽可能减少不必要的prepareCall调用,重用CallableStatement对象.

2.注册输出参数(如果有的话)

要得到输出参数的值(创建存储过程时设置的OUT和INOUT),JDBC要求这些参数必须要在数据库操作执行之前通过registerOutputPrameter()方法设置.


  1. import java.sql.Types;

  2. ...

  3. //

  4. // 下面给出了设置输出参数的几个方法

  5. //

  6. // 注册第二个参数为输出参数

  7. //

  8. cStmt.registerOutParameter(2);

  9. //

  10. // 注册第二个参数为输出参数,设定getObject得到的返回值的类型为整型

  11. //

  12. cStmt.registerOutParameter(2, Types.INTEGER);

  13. //

  14. // 注册名为"inOutParam"的参数为输出参数

  15. //

  16. cStmt.registerOutParameter("inOutParam");

  17. //

  18. // 注册名为"inOutParam"的参数为输出参数,设定getObject得到的返回值的类型为整型

  19. //

  20. cStmt.registerOutParameter("inOutParam", Types.INTEGER);


3.设置输入参数(如果有的话)
类似PreparedStatement的设置参数方法.


  1. //

  2. // 设置第一个参数值

  3. //

  4. cStmt.setString(1, "abcdefg");

  5. //

  6. // 根据名字设置参数值

  7. //

  8. cStmt.setString("inputParameter", "abcdefg");

  9. //

  10. // 根据索引值设置输入/输出参数

  11. //

  12. cStmt.setInt(2, 1);

  13. //

  14. // 根据参数名设置输入/输出参数

  15. //

  16. //

  17. cStmt.setInt("inOutParam", 1);

  18. ...



4.执行CallableStatement,获取结果集合或输出参数
尽管CallableStatement支持Statement接口的所有执行方法(executeUpdate(),executeQuery()或execute()),最具伸缩性的方法是execute(),因为你不需要知道是否这个存储过程返回结果集合.


  1. ...

  2. boolean hadResults = cStmt.execute();

  3. //

  4. // 处理返回的结果集合

  5. //

  6. while (hadResults) {

  7. ResultSet rs = cStmt.getResultSet();

  8. //

  9. ...

  10. hadResults = cStmt.getMoreResults();

  11. }

  12. //

  13. // 获取输出参数,通过索引值或参数名

  14. //

  15. //

  16. int outputValue = cStmt.getInt(1);

  17. outputValue = cStmt.getInt("inOutParam");


关于“MySQL中如何使用存储过程”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL中如何使用存储过程

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何在 PHP 中使用 MySQL 存储过程?

要在 php 中使用 mysql 存储过程:使用 pdo 或 mysqli 扩展连接到 mysql 数据库。准备调用存储过程的语句。执行存储过程。处理结果集(如果存储过程返回结果)。关闭数据库连接。如何在 PHP 中使用 MySQL 存储过
如何在 PHP 中使用 MySQL 存储过程?
2024-05-11

php+mysql如何使用存储过程

这篇文章主要介绍“php+mysql如何使用存储过程”,在日常操作中,相信很多人在php+mysql如何使用存储过程问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”php+mysql如何使用存储过程”的疑惑有所
2023-04-19

如何在MySQL中使用存储过程和函数?

如何在MySQL中使用存储过程和函数?在MySQL中,存储过程和函数是被封装的一组SQL语句,可以被重复调用。存储过程是一组可以在服务器上执行的SQL语句集合,而函数则是一个独立的且可重用的代码块。两者的不同之处在于,存储过程可以返回多个结
2023-10-22

如何在MySQL中使用Python编写存储过程

标题:MySQL中使用Python编写存储过程的示例及实践指南在MySQL中使用存储过程可以有效地将复杂的数据库操作封装起来,提高数据库的执行效率和安全性。本文将介绍如何使用Python编写MySQL的存储过程,并提供具体的代码示例供参考。
2023-10-22

如何在MySQL中使用C#编写存储过程

如何在MySQL中使用C#编写存储过程在MySQL数据库中,存储过程是一组预定义的SQL语句,可以以一定的逻辑顺序组合成一个单元的程序。它可以用于简化和优化数据库操作,并提高应用程序的性能和安全性。C#是一种广泛使用的编程语言,具有强大的数
2023-10-22

MySQL IF 语句如何在存储过程中使用?

MySQL IF 语句在存储过程中实现基本条件构造。其语法如下 -IF expression THENStatements;END IF;它必须以分号结尾。为了演示 IF 语句在 MySQL 存储过程中的使用,我们将创建以下存储过程,该
2023-10-22

MySQL存储过程中如何使用局部变量?

局部变量是在存储过程中声明的变量。它们仅在声明它们的 BEGIN…END 块内有效,并且可以具有任何 SQL 数据类型。为了演示它,我们正在创建以下过程 -mysql> DELIMITER // ;mysql> Create Proced
2023-10-22

mysql如何调用存储过程

在MySQL中调用存储过程可以使用CALL语句。语法如下:```CALL procedure_name([parameter1, parameter2, ...]);```其中,procedure_name是存储过程的名称,paramete
2023-08-11

编程热搜

目录