java调用存储过程CallableStatement问题

xurongsz 2006-12-07 10:43:35
数据库中的
Sno int,
Sname varchar(20),
Scourse varchar(30),
Sscore int
)
insert into score values(1,'张三','语文',90);
insert into score values(1,'张三','数学',95);
insert into score values(1,'张三','英语',85);
insert into score values(2,'李四','语文',91);
insert into score values(2,'李四','数学',92);
insert into score values(2,'李四','英语',82);

create proc score1(@no int)
as
select avg(Sscore) from score where Sno=@no

JAVA中
Connection conn;
try {
conn = DriverManager.getConnection(url,user,password);
Statement stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
ResultSet rs = stmt.executeQuery(strsql);
while(rs.next()) {
aa=rs.getString("Sno");//可以读取数据
bb=rs.getString("Sname");
cc=rs.getString("Sscore");
rs.next();
dd=rs.getString("Sscore");
rs.next();
ee=rs.getString("Sscore");
CallableStatement cstmt=conn.prepareCall(
"{call score1(?)}");
int aaa = Integer.parseInt(aa);
cstmt.setInt(1, aaa);
cstmt.registerOutParameter(1, Types.INTEGER);
cstmt.executeUpdate();//这里无法执行,不知道为什么?
int fff=cstmt.getInt(1);
ff=Integer.toString(fff);
break;
}
} catch (SQLException e) {
label.setText("连接不成功");
}
...全文
373 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
xurongsz 2006-12-09
  • 打赏
  • 举报
回复
郁闷,不知道java调用存储过程怎么实现?
yunbaixingxing 2006-12-08
  • 打赏
  • 举报
回复
马克
poska 2006-12-08
  • 打赏
  • 举报
回复
不知道楼主什么意思,
int fff=cstmt.getInt(1); 这个已经得到了楼主想要的平均分啊.
再处理不就行了吗???
xurongsz 2006-12-08
  • 打赏
  • 举报
回复
create database student;

create table score(
Sno int,
Sname varchar(20),
Scourse varchar(30),
Sscore int
)

insert into score values(1,'张三','语文',90);
insert into score values(1,'张三','数学',95);
insert into score values(1,'张三','英语',85);
insert into score values(2,'李四','语文',91);
insert into score values(2,'李四','数学',92);
insert into score values(2,'李四','英语',82);

create proc score1(@no int)
as
select avg(Sscore) from score where Sno=@no

这个存储过程的目的是得到某个人的成绩平均分。
不知道如何在java中得到这个平均分。
kingofworl 2006-12-08
  • 打赏
  • 举报
回复
cstmt.executeUpdate();//
改成cstmt.execute();//试试看
poska 2006-12-08
  • 打赏
  • 举报
回复
不好意思,有点看错.
将 cstmt.executeUpdate();中的Update去掉即可........
poska 2006-12-08
  • 打赏
  • 举报
回复
cstmt.registerOutParameter(1, Types.INTEGER);

又没有OUT对象,注册干什么呀,去掉这句话,就行了

注册的话用cstmt.registerOutParameter(1, Java.sql.Types.INTEGER);
注意,以下使用数据库为sql2000,驱动jtds1.2.2 一、调用存储过程(无结果集返回) Connection connection = ConnectionHelper.getConnection(); CallableStatement callableStatement = connection.prepareCall("{ call procedureName(?,?) }"); callableStatement.setString(1, "xxxxxxxx"); callableStatement.setString(2, "xxxxxxxx"); callableStatement.execute(); //获得sql的消息并输出,这个估计很多人都需要 SQLWarning sqlWarning = callableStatement.getWarnings(); while (sqlWarning != null) { System.out.println("sqlWarning.getErrorCode() = " + sqlWarning.getErrorCode()); System.out.println("sqlWarning.getSQLState() = " + sqlWarning.getSQLState()); System.out.println("sqlWarning.getMessage() = " + sqlWarning.getMessage()); sqlWarning = sqlWarning.getNextWarning(); } //close ConnectionHelper.closeConnection(callableStatement, connection); 二、调用存储过程,返回sql类型数据(非记录集) Connection connection = ConnectionHelper.getConnection(); CallableStatement callableStatement = connection.prepareCall("{ call procedureName(?,?,?) }"); callableStatement.setString(1, "xxxxxxxx"); callableStatement.setString(2, "xxxxxxxx"); //重点是这句1 callableStatement.registerOutParameter(3, Types.INTEGER); callableStatement.execute(); //取返回结果,重点是这句2 //int rsCount = callableStatement.getInt(3); //close ConnectionHelper.closeConnection(callableStatement, connection); 三、重点来了,返回记录集,多记录集 注意,不需要注册返回结果参数,只需要在sql中select出结果即可 例如:select * from tableName 即可得到返回结果 Connection connection = ConnectionHelper.getConnection(); CallableStatement callableStatement = connection.prepareCall("{ call procedureName(?) }"); //此处参数与结果集返回没有关系 callableStatement.setString(1, "xxxxxxxx"); callableStatement.execute(); ResultSet resultSet = callableStatement.getResultSet(); //以上两个语句,可以使用ResultSet resultSet = callableStatement.executeQuery();替代 //多结果返回 ResultSet resultSet2; if (callableStatement.getMoreResults()) { resultSet2 = callableStatement.getResultSet(); while (resultSet2.next()) { } } //close ConnectionHelper.closeConnection(callableStatement, connection); 提示:多结果返回可以使用如下代码(以上主要让大家明白,单一结果和多结果的区别): Boolean hasMoreResult = true; while (hasMoreResult) { ResultSet resultSet = callableStatement.getResultSet(); while (resultSet.next()) { } hasMoreResult = callableStatement.getMoreResults(); }

62,629

社区成员

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

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