ResultSet未打开。不允许操作GetMetaData

时间:2014-03-17 22:23:11

标签: java swing derby

我遇到了数据库类的问题,我有2个方法。应该用数据库中的数据填充JTable。 问题是我收到错误(tittle)。这是我的代码:

public class QueryModel {

private Connection connection = null;
private ResultSet resultSet = null;
private Statement statement = null;
private ResultSetMetaData metaData = null;

public void sendStatement(CreateDataBase database,String query)
{
    try 
    {
        connection = database.getConnection();
    } 
    catch (SQLException | ClassNotFoundException e) 
    {
        System.err.println(e);
    }

    if (!query.equals("")) 
        {
            try 
            {
                statement = connection.createStatement();
                resultSet = statement.executeQuery(query);
                metaData = resultSet.getMetaData();

                if (statement.execute(query))
                {
                    System.out.println("Result:");
                    JTable table = new JTable(buildTableModel());
                    JOptionPane.showMessageDialog(null, new JScrollPane(table));
                }
                else 
                {
                    System.out.println("Executed!");
                }
                statement.close();
            } 
            catch (SQLException e) 
            {
                System.err.println(e);
            }
        }
}

public DefaultTableModel buildTableModel() throws SQLException 
{
    // 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 (resultSet.next()) 
    {
        Vector<Object> vector = new Vector<Object>();
        for (int columnIndex = 1; columnIndex <= columnCount; columnIndex++) 
            vector.add(resultSet.getObject(columnIndex));
        data.add(vector);
    }

    return new DefaultTableModel(data, columnNames);
}

}

在我看来问题似乎是getMetaData函数,没有这个每个查询都顺利进行。我添加这个时就开始出问题。我还没有使用过这个,所以我不知道如何处理这个,不知道是否有任何意图来尝试修复它而不是这样做。比如手动更多。

2 个答案:

答案 0 :(得分:0)

狮子座是对的。 MetaData对象来自第一个ResultSet,当您重新执行查询时,该ResultSet将关闭。不要执行两次查询,或者如果必须,请确保从实际导航的结果集中获取“新鲜”的MetaData对象。

答案 1 :(得分:0)

在“if”子句中第二次执行查询时,您隐式关闭了第一个结果集。

我的意思是,resultset是指向executeQuery()中定义的对象的指针,然后您将隐式重新定义execute(query)中的结果集。

那是因为你要查询两次。

尝试从if块中定义元数据,看看它是否有效(可能会)