添加链接
link之家
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
相关文章推荐
帅呆的马克杯  ·  Hive SQL(5)-lateral ...·  1 年前    · 
活泼的弓箭  ·  mysqldump - 知乎·  2 年前    · 

下载 JDBC 驱动程序

可以调用的 SQL Server 存储过程是一个返回状态或结果参数的存储过程。 此状态通常用于指示存储过程执行成功还是失败。 可以使用 Microsoft JDBC Driver for SQL Server 提供的 SQLServerCallableStatement 类,调用此类存储过程并处理其返回的数据。

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

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

若要详细了解 SQL 转义序列,请参阅 使用 SQL 转义序列

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

当 JDBC 驱动程序与 SQL Server 数据库一起使用时,registerOutParameter 方法中为返回状态参数指定的值将始终为整数,可通过使用 java.sql.Types.INTEGER 数据类型进行指定。

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

作为示例,在 AdventureWorks2022 示例数据库中创建以下存储过程:

CREATE PROCEDURE CheckContactCity  
   (@cityName CHAR(50))  
BEGIN  
   IF ((SELECT COUNT(*)  
   FROM Person.Address  
   WHERE City = @cityName) > 1)  
   RETURN 1  
   RETURN 0  

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

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

public static void executeStoredProcedure(Connection con) {
    try(CallableStatement cstmt = con.prepareCall("{? = call dbo.CheckContactCity(?)}");) {
        cstmt.registerOutParameter(1, java.sql.Types.INTEGER);
        cstmt.setString(2, "Atlanta");
        cstmt.execute();
        System.out.println("RETURN STATUS: " + cstmt.getInt(1));
    // Handle any errors that may have occurred.
    catch (SQLException e) {
        e.printStackTrace();

结合使用语句和存储过程