JDBC存储过程调用

时间:2015-03-25 06:45:29

标签: java mysql java-stored-procedures

我创建了一个存储过程,如下所示:

// mysql中的存储过程

DELIMITER $$
CREATE PROCEDURE `bank`.`hello` (in id varchar(20),in pass varchar(20))
BEGIN
 insert into admin(username,password) values (id,pass);
END $$
DELIMITER ;

我在java中调用存储过程如下:

//使用JDBC调用存储过程

package StoredProcEx;
import java.sql.*;
public class StoredProcEx {
    public static void main(String arg[]){
    try{

    Class.forName("com.mysql.jdbc.Driver");
    Connection con=DriverManager.getConnection("jdbc:mysql://localhost:3306/bank","root","root");
    //PreparedStatement stmt=con.prepareStatement("insert into admin values(?,?)");
    CallableStatement stmt=con.prepareCall("{?=call hello(?,?)}");
    stmt.setString(1,"birender");
    stmt.setString(2,"admin");
    stmt.execute();
    //stmt.execute();
    }
    catch(ClassNotFoundException ce){
    ce.printStackTrace();
    }
    catch(SQLException se){
     se.printStackTrace();
    }
    catch(Exception e){}
    }
}

但它显示编译时异常如下:

可以为存储的函数调用的返回值设置IN参数。

1 个答案:

答案 0 :(得分:3)

请使用

CallableStatement stmt=con.prepareCall("{call hello(?,?)}");

而不是

CallableStatement stmt=con.prepareCall("{?=call hello(?,?)}");

首先?在您的代码中用于返回类型