JSP中如何嵌套执行两条SQL语句,SELECT后将按成绩排序好的结果通过ID然后插入排名,怎么执行不了啊

Connectionconn=DriverManager.getConnection(connectDB,Dbuser,Dbpassword);System.out.pr... Connection conn=DriverManager.getConnection(connectDB,Dbuser,Dbpassword);
System.out.println("连接数据库成功");
String sql = "SELECT 学号,本次班级排名 FROM "+name+" ORDER BY 总分 DESC";
stmt = conn.prepareStatement(sql);
rs=stmt.executeQuery();
while(rs.next())
{
int id=Integer.valueOf(rs.getString(1));

int j=1;

Connection conn1=DriverManager.getConnection(connectDB,Dbuser,Dbpassword);
System.out.println("连接数据库成功");

String sql1 = "UPDATE "+name+" set xiaopaiming=? WHERE id=?";
stmt1 = conn1.prepareStatement(sql1);
stmt1.setInt(1,j);
stmt1.setInt(2,id);
stmt1.executeUpdate(sql1);
j++;System.out.println(name);

stmt1.close();//关闭命令对象连接;
conn1.close();//关闭数据库连接;
}
stmt.close();//关闭命令对象连接;
conn.close();//关闭数据库连接;
原来运行后显示 学号 姓名 班级 语文 总分 校排名 变动 班级排名
13 欧尼 23 43 43 1
。 。 。。。

现在:
学号
姓名
班级
语文 总分
校排名
变动
班级排名
后面没结果了
展开
 我来答
victorzhangyan
2013-06-16 · TA获得超过355个赞
知道小有建树答主
回答量:158
采纳率:0%
帮助的人:110万
展开全部
Connection conn1=DriverManager.getConnection(connectDB,Dbuser,Dbpassword);
System.out.println("连接数据库成功");

把这行去掉
其实你完全可以都使用一套,比如conn1,sql1,stmt1这些都用上一个conn...然后所有都执行完之后,在调用stmt.close,conn.close
更多追问追答
追问
我这样改后运行时还是只运行一遍while(rs.next())语句,结果显示不了
追答
奥 我明白了 其实你可以新建一个类,类的属性是你需要的表中的信息,然后查询到数据库中一行信息,就将该条信息赋值给一个新的对象,然后将该新的对象添加到一个容器中,然后再针对容器中的所有对象再用循环一个个插到数据库中。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式