存储过程,请指点

setnever 2004-09-06 12:05:03
这是我创建存储过程的脚本
create procedure myproc
(
@max int output,
@rs varchar(20)
)
as
set @max=(select max(job_id) from employee)
select @max
select emp_id,fname,lname from employee where emp_id like '%' + @rs + '%'
go

java程序
import java.sql.*;
public class aaa
{
public static void main(String args[])
{
try
{
Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");
Connection cn=DriverManager.getConnection("jdbc:microsoft:sqlserver://localhost:1433;databasename=pubs","sa","");
String sql = "{call myproc(?,?)}";
CallableStatement cstmt = cn.prepareCall(sql);
cstmt.registerOutParameter(1,Types.INTEGER);//output 型的参数
cstmt.setString(2,"a");//input 型的参数
ResultSet rs=cstmt.executeQuery();
System.out.println(cstmt.getString(1));//打印出output计算出来的值
while(rs.next())
{
System.out.println(rs.getString(1));
}

}
catch(Exception e)
{
System.out.println(e.getMessage());
}
}
}
现在就是那个output型参数传进去后程序里能接到计算出后的值,但是那个结果集怎么处理,在while里循环打印的地方可能有些问题,异常是[Microsoft][SQLServer 2000 Driver for JDBC]Object has been closed.,我想又能接到output计算出后的值,又能接到结果集在前端打印,怎么做?
请高手指点
...全文
65 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

62,623

社区成员

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

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