Java调用SQL Server的存储过程详解

发表于:2012-5-11 09:22

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:希望未来    来源:51Testing软件测试网采编

分享:

  作为实例,在 SQL Server 2005 AdventureWorks 示例数据库中创建以下存储过程: 根据指定的整数 IN 参数 (employeeID),该存储过程也返回单个整数 OUT 参数 (managerID)。根据 HumanResources.Employee 表中包含的 EmployeeID,OUT 参数中返回的值为 ManagerID。

  在下面的实例中,将向此函数传递 AdventureWorks 示例数据库的打开连接,然后使用 execute 方法调用 GetImmediateManager 存储过程:

  1. public static void executeStoredProcedure(Connection con) ...{  
  2.  try ...{  
  3.  CallableStatement cstmt = con.prepareCall("{call dbo.GetImmediateManager(?, ?)}");  
  4.  cstmt.setInt(15);  
  5.  cstmt.registerOutParameter(2, java.sql.Types.INTEGER);  
  6.  cstmt.execute();  
  7.  System.out.println("MANAGER ID: " + cstmt.getInt(2));  
  8.  }  
  9.  catch (Exception e) ...{  
  10.  e.printStackTrace();  
  11.  }  
  12. }

  本示例使用序号位置来标识参数。或者,也可以使用参数的名称(而非其序号位置)来标识此参数。下面的代码示例修改了上一个示例,以说明如何在 Java 应用程序中使用命名参数。请注意,这些参数名称对应于存储过程的定义中的参数名称: 11x16CREATE PROCEDURE GetImmediateManager

  1.  @employeeID INT,  
  2.  @managerID INT OUTPUT 
  3. AS 
  4. BEGIN 
  5.  SELECT @managerID = ManagerID  
  6.  FROM HumanResources.Employee  
  7.  WHERE EmployeeID = @employeeID  
  8. END

  存储过程可能返回更新计数和多个结果集。Microsoft SQL Server 2005 JDBC Driver 遵循 JDBC 3.0 规范,此规范规定在检索 OUT 参数之前应检索多个结果集和更新计数。也就是说,应用程序应先检索所有 ResultSet 对象和更新计数,然后使用 CallableStatement.getter 方法检索 OUT 参数。否则,当检索 OUT 参数时,尚未检索的 ResultSet 对象和更新计数将丢失。

  4、使用带有返回状态的存储过程

  使用 JDBC 驱动程序调用这种存储过程时,必须结合 SQLServerConnection 类的 prepareCall 方法使用 call SQL 转义序列。返回状态参数的 call 转义序列的语法如下所示:

{[?=]call procedure-name[([parameter][,[parameter]]...)]}

  构造 call 转义序列时,请使用 ?(问号)字符来指定返回状态参数。此字符充当要从该存储过程返回的参数值的占位符。要为返回状态参数指定值,必须在执行存储过程前使用 SQLServerCallableStatement 类的 registerOutParameter 方法指定参数的数据类型。

  此外,向 registerOutParameter 方法传递返回状态参数值时,不仅需要指定要使用的参数的数据类型,还必须指定参数在存储过程中的序数位置。对于返回状态参数,其序数位置始终为 1,这是因为它始终是调用存储过程时的第一个参数。尽管 SQLServerCallableStatement 类支持使用参数的名称来指示特定参数,但您只能对返回状态参数使用参数的序号位置编号。

  作为实例,在 SQL Server 2005 AdventureWorks 示例数据库中创建以下存储过程:

  1. CREATE PROCEDURE CheckContactCity  
  2.  (@cityName CHAR(50))  
  3. AS 
  4. BEGIN 
  5.  IF ((SELECT COUNT(*)  
  6.  FROM Person.Address  
  7.  WHERE City = @cityName) > 1)  
  8.  RETURN 1  
  9. ELSE 
  10.  RETURN 0  
  11. END

  该存储过程返回状态值 1 或 0,这取决于是否能在表 Person.Address 中找到 cityName 参数指定的城市。

32/3<123>
价值398元的测试课程免费赠送,填问卷领取吧!

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计

法律顾问:上海漕溪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2022
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号