天天看点

存储过程之七—java代码调用

一、简介

  jdbc调用存储过程与调用一般的sql语句有些差别。jdbc调用一般的sql语句的时候,返回的是结果集,或是sql语句后是否执行成功的标记量。而存储过程返回的可以是结果集,输出参数、返回状态和受影响行数。而mysql存储过程不支持return,所以只有剩下的三种返回方式。

  调用的过程一般如下:

  1、创建连接 Connection conn = DriverManager.getConnection(url, user, password);

  2、创建CallableStatement CallableStatement statement = conn.prepareCall(sql);

  3、设置参数

    statement.setInt(1, id);

    statement.registerOutParameter(2, Types.VARCHAR);

    statement.registerOutParameter(3, Types.INTEGER);

    statement.registerOutParameter(4, Types.VARCHAR);

   4、执行

    statement.execute(); 或 statement.executeUpdate();

  5、获取返回

    int age = statement.getInt(3);或ResultSet resultSet = statement.executeQuery();

二、实例

  以下存储过程表结构如下:

   1、增加记录(输入输出参数的调用)

     存储过程如下:

    调用代码如下:

    对于输出参数需要调用statement.registerOutParameter(4, Types.INTEGER)进行注册,执行之后通过statement.getInt()方法来获取。

   2、修改记录(输入输出参数的调用)

    存储过程如下:

  3、删除记录(使用statement.getUpdateCount()获取影响行数)

   4、查询一条记录(输入输出)

     存储过程如下:

    使用在SELECT语句中使用INTO给输出参数赋值

  5、查询一个集合(返回一个集合)

     通过statement.executeQuery()方法返回已经ResultSet,再对ResultSet进行遍历。

  关于存储过程存在into参数的时候,java代码中在设置输入参数之后,还需要注册输出参数,调用之后通过statement.get..方法拿到输出参数的值。如下: