我在ResultSet上经历了一段非常糟糕的时光,它在while循环中关闭以迭代此ResultSet。我知道ResultSet关闭的确切行,但是我不知道为什么。
public LinkedList<Athlet> alleAbrufen () throws SQLException {
LinkedList<Athlet> alleAthleten = new LinkedList<Athlet>();
String abrufenAthleten = "SELECT * FROM Athlet ORDER BY athlet_id";
ResultSet athleten_rs = stmt.executeQuery(abrufenAthleten);
while (athleten_rs.next()) {
long id = athleten_rs.getInt(1);
String name = athleten_rs.getString(2);
LinkedList<Leistung> alleLeistungen = alleAbrufen((int) (id)); //after this line the ResultSet gets closed
alleAthleten.add(new Athlet(id, name, alleLeistungen));
}
return alleAthleten;
}
public LinkedList<Leistung> alleAbrufen(int athlet_id) throws SQLException {
LinkedList<Leistung> alleLeistungen = new LinkedList<Leistung>();
String selectLeistungen = "SELECT * FROM Leistung WHERE athlet_id="+athlet_id;
ResultSet rs = stmt.executeQuery(selectLeistungen);
while (rs.next()) {
long id = rs.getInt(1);
String bezeichnung = rs.getString(2);
String datum = rs.getString(3);
double geschwindigkeit = rs.getDouble(4);
boolean selectedForSlopeFaktor = rs.getBoolean(5);
int strecke_id = rs.getInt(7);
long longAthlet_id = (long) athlet_id;
Leistung leistung = new Leistung(strecke_id, longAthlet_id, bezeichnung, datum, geschwindigkeit);
leistung.setLeistungID(id);
leistung.setIsUsedForSlopeFaktor(selectedForSlopeFaktor);
alleLeistungen.add(leistung);
}
return alleLeistungen;
}
我ResultSet
用注释标记了该行,之后该行关闭了。Alle
上面示例中使用的其他方法,构造函数等都经过了正常测试。有谁知道为什么调用第二个方法会关闭ResultSet
第一个方法的线索?
问题在于,每个执行的语句Statement
只能维护一组ResultSet
。既然你共享同Statement stmt
为你的两个方法,在alleAbrufen
该Statement
执行另一份声明,这将打破参照之前ResultSet
。
针对这种情况的最佳解决方案是创建Statement
每个语句执行。也就是说,每个方法都应包含其唯一Statement
且相关ResultSet
的。
public LinkedList<Athlet> alleAbrufen () throws SQLException {
LinkedList<Athlet> alleAthleten = new LinkedList<Athlet>();
String abrufenAthleten = "SELECT * FROM Athlet ORDER BY athlet_id";
//here
Statement stmtAlleAbrufen = con.createStatement();
ResultSet athleten_rs = stmtAlleAbrufen.executeQuery(abrufenAthleten);
while (athleten_rs.next()) {
long id = athleten_rs.getInt(1);
String name = athleten_rs.getString(2);
LinkedList<Leistung> alleLeistungen = alleAbrufen((int) (id)); //after this line the ResultSet gets closed
alleAthleten.add(new Athlet(id, name, alleLeistungen));
}
return alleAthleten;
}
public LinkedList<Leistung> alleAbrufen(int athlet_id) throws SQLException {
LinkedList<Leistung> alleLeistungen = new LinkedList<Leistung>();
//here again, but since you need to use parameters in your query
//use PreparedStatement instead
//note that I commented the current query
//String selectLeistungen = "SELECT * FROM Leistung WHERE athlet_id="+athlet_id;
//this is how a query with parameters look like
String selectLeistungen = "SELECT * FROM Leistung WHERE athlet_id=?";
//the connection prepares the statement
PreparedStatement pstmt = con.prepareStatement(selectLeistungen);
//then we pass the parameters
pstmt.setInt(1, athlet_id);
ResultSet rs = pstmt.executeQuery();
while (rs.next()) {
long id = rs.getInt(1);
String bezeichnung = rs.getString(2);
String datum = rs.getString(3);
double geschwindigkeit = rs.getDouble(4);
boolean selectedForSlopeFaktor = rs.getBoolean(5);
int strecke_id = rs.getInt(7);
long longAthlet_id = (long) athlet_id;
Leistung leistung = new Leistung(strecke_id, longAthlet_id, bezeichnung, datum, geschwindigkeit);
leistung.setLeistungID(id);
leistung.setIsUsedForSlopeFaktor(selectedForSlopeFaktor);
alleLeistungen.add(leistung);
}
return alleLeistungen;
}
使用完资源后,别忘了关闭资源Statement
和ResultSet
。
问题内容: 以下站点显示了通过JDBC使用新的“ AutoClosable”功能:link。该站点显示了如何自动关闭该语句,但是结果集不在自动关闭该语句的try()节中。因此,我的问题是,是否不需要在Java 7中直接关闭ResultSets?我一直使用这种模式:关闭结果集,关闭语句,关闭连接。 问题答案: 从ResultSet的Javadoc中: 当关闭,重新执行或用于生成多个结果序列中的下一个
loop变量等同于具有真值的while循环( while true )。 这个循环中的语句将重复执行,直到我们使用break语句退出循环。 语法 (Syntax) 下面给出了CoffeeScript中while循环的循环替代语法。 loop statements to be executed repeatedly condition to exit the loop 例子 (Exam
问题内容: 看来我关闭时会自动关闭。但是我想返回并在另一种方法中使用它,所以我不知道在何处关闭and 。 我进入catch块是因为我发现,如果将它放在finally块中,我将在它返回之前立即丢失我的数据。现在当我想关闭时,我无法关闭和。有什么解决办法吗? 问题答案: 使用用于断开后持有信息
我试图运行一些类似于下面的代码...我想我对for循环有一个根本性的误解。我想迭代一个for循环,如果每次迭代的条件都满足(X==True),我想完成那个迭代,如果它不满足/否则我想看看它是否满足第二个条件(Z==True)...如果是这样,我想继续做事情2,并在条件为真时将其计算为迭代,一旦它不再为真,我希望它运行另一个for循环做事情3 5次,然后在下一次迭代中返回到原始if语句。如果第二个条
我在尝试为do while循环执行try catch时遇到了一些问题:
这很好,Orika自动确定bean上的属性名,并在expr中给我。但它没有告诉我类型。它也没有告诉我我试图映射到什么。在本例中,我只需假设目标是ResultSet。 如何知道要将数据放入的expr的类型?如果是,我将进行内联绑定调用,并告诉Orika使用。如果是时间戳,我将进行内联绑定调用并告诉Orika使用 我如何知道我试图从映射到,而不是从映射到?