关于JAVA存储过程的一个难题请各位大虾帮忙解决

44290029 2004-08-26 05:17:02
注:这是两个调用存储地程的方法的片断
第一个可执行 call testLM ( ?,?,?,?,?,?,? ) ;
第二个执行时取不到返回值
“begin testLM('1','aaa','bbb','ccc','ddd','eee',DM);end;” 这个是调用存储过程的SQL在 PL/SQL里可执行;

public void TestProcure() {
try {
java.sql.Connection con = ConnectionManager.getConnection();
java.sql.CallableStatement temp = con.prepareCall(
"{ call testLM ( ?,?,?,?,?,?,? ) }");
temp.registerOutParameter(7, Types.VARCHAR);

temp.setString(1, "1");
temp.setString(2, "aaa");
temp.setString(3, "bbb");
temp.setString(4, "ccc");
temp.setString(5, "ddd");
temp.setString(6, "eee");
temp.execute();
String re_value = temp.getString(7);
System.out.println(re_value);
}
catch (SQLException ex) {
ex.printStackTrace();
}

}

public void TestProcure1() {
try {
java.sql.Connection con = ConnectionManager.getConnection();
String sql = "DECLARE DM VARCHAR2(20); begin testLM('1','aaa','bbb','ccc','ddd','eee',DM);end;";
java.sql.CallableStatement temp = con.prepareCall(sql);
//temp.registerOutParameter(7, Types.VARCHAR);
temp.execute();
String re_value = temp.getString(7);
System.out.println(re_value);
}
catch (SQLException ex) {
ex.printStackTrace();
}
}
...全文
64 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

62,614

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧