程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> Java調用SQL Server的存儲過程詳解(2)

Java調用SQL Server的存儲過程詳解(2)

編輯:關於JAVA

4 使用帶有返回狀態的存儲過程

使用 JDBC 驅動程序調用這種存儲過程時,必須結合 SQLServerConnection 類的 prepareCall 方法使用 call SQL 轉義序列。返回狀態參數的 call 轉義序列的語法如下所示:

  1. {[?=]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 參數指定的城市。

在下面的實例中,將向此函數傳遞 AdventureWorks 示例數據庫的打開連接,然後使用 execute 方法調用 CheckContactCity 存儲過程:

  1.  public static void executeStoredProcedure(Connection con) ...{
  2. try ...{
  3. CallableStatement cstmt = con.prepareCall("{? = call dbo.CheckContactCity(?)}");
  4. cstmt.registerOutParameter(1, Java.sql.Types.INTEGER);
  5. cstmt.setString(2, "Atlanta");
  6. cstmt.execute();
  7. System.out.println("RETURN STATUS: " + cstmt.getInt(1));
  8. }
  9. cstmt.close();
  10. catch (Exception e) ...{
  11. e.printStackTrace();
  12. }
  13. }

5 使用帶有更新計數的存儲過程

使用 SQLServerCallableStatement 類構建對存儲過程的調用之後,可以使用 execute 或 executeUpdate 方法中的任意一個來調用此存儲過程。executeUpdate 方法將返回一個 int 值,該值包含受此存儲過程影響的行數,但 execute 方法不返回此值。如果使用 execute 方法,並且希望獲得受影響的行數計數,則可以在運行存儲過程後調用 getUpdateCount 方法。

作為實例,在 SQL Server 2005 AdventureWorks 示例數據庫中創建以下表和存儲過程:

  1. CREATE TABLE TestTable
  2. (Col1 int IDENTITY,
  3. Col2 varchar(50),
  4. Col3 int);
  5. CREATE PROCEDURE UpdateTestTable
  6. @Col2 varchar(50),
  7. @Col3 int
  8. AS
  9. BEGIN
  10. UPDATE TestTable
  11. SET Col2 = @Col2, Col3 = @Col3
  12. END;

在下面的實例中,將向此函數傳遞 AdventureWorks 示例數據庫的打開連接,並使用 execute 方法調用 UpdateTestTable 存儲過程,然後使用 getUpdateCount 方法返回受存儲過程影響的行計數。

  1. public static void executeUpdateStoredProcedure(Connection con) ...{
  2. try ...{
  3. CallableStatement cstmt = con.prepareCall("{call dbo.UpdateTestTable(?, ?)}");
  4. cstmt.setString(1, "A");
  5. cstmt.setInt(2, 100);
  6. cstmt.execute();
  7. int count = cstmt.getUpdateCount();
  8. cstmt.close();
  9. System.out.println("ROWS AFFECTED: " + count);
  10. }
  11. catch (Exception e) ...{
  12. e.printStackTrace();
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved