gpt4 book ai didi

java - 从 ResultSet 元数据调用 getColumnCount() 时出错

转载 作者:行者123 更新时间:2023-11-30 10:31:33 25 4
gpt4 key购买 nike

我在尝试从结果集的元数据中获取列数时似乎遇到了问题。错误是线程“AWT-EventQueue-0”java.lang.IllegalStateException 中的异常:SQLite JDBC:内部状态不一致。

想法是使用此表模型将数据库查询的结果填充到 JTable 中。但是,当我这样做时,出现上述错误。

相关代码为:

public DefaultTableModel buildFlightModel()
throws SQLException {

query="SELECT Airline.AirlineName, Flight.FlightID, Flight.Location, Flight.Destination, Flight.ArriveTime, Flight.LeaveTime FROM Flight INNER JOIN Airline ON Airline.AirlineID=Flight.AirlineID;";

try {
Class.forName("org.sqlite.JDBC");
c = DriverManager.getConnection("jdbc:sqlite:coursework.db");
stmt = c.createStatement();
rs=stmt.executeQuery(query);
while(rs.next()){
//System.out.println(s);
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
ResultSetMetaData metaData = rs.getMetaData();

// names of columns
Vector<String> columnNames = new Vector<String>();
int columnCount = metaData.getColumnCount();
for (int column = 1; column <= columnCount; column++) {
columnNames.add(metaData.getColumnName(column));
}

// data of the table
Vector<Vector<Object>> data = new Vector<Vector<Object>>();
while (rs.next()) {
Vector<Object> vector = new Vector<Object>();
for (int columnIndex = 1; columnIndex <= columnCount; columnIndex++) {
vector.add(rs.getObject(columnIndex));
}
data.add(vector);
}

return new DefaultTableModel(data, columnNames);

}

任何想法/想法/帮助将不胜感激。谢谢。

最佳答案

ResultSet.isclose() == true 时抛出此异常。在开始读取循环之前尝试创建 MetaDataClone

关于java - 从 ResultSet 元数据调用 getColumnCount() 时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43148515/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com