【问题标题】:Error when calling getColumnCount() from ResultSet metadata从 ResultSet 元数据调用 getColumnCount() 时出错
【发布时间】:2017-08-26 04:30:34
【问题描述】:

在尝试从结果集的元数据中获取库计数时,我似乎遇到了问题。错误是线程“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);

    }

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

【问题讨论】:

标签: java sqlite jtable resultset defaulttablemodel


【解决方案1】:

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

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2017-12-29
    • 1970-01-01
    • 2012-05-23
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多