我遇到了数据库类的问题,我有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函数,没有这个每个查询都顺利进行。我添加这个时就开始出问题。我还没有使用过这个,所以我不知道如何处理这个,不知道是否有任何意图来尝试修复它而不是这样做。比如手动更多。
答案 0 :(得分:0)
狮子座是对的。 MetaData对象来自第一个ResultSet,当您重新执行查询时,该ResultSet将关闭。不要执行两次查询,或者如果必须,请确保从实际导航的结果集中获取“新鲜”的MetaData对象。
答案 1 :(得分:0)
在“if”子句中第二次执行查询时,您隐式关闭了第一个结果集。
我的意思是,resultset是指向executeQuery()中定义的对象的指针,然后您将隐式重新定义execute(query)中的结果集。
那是因为你要查询两次。
尝试从if块中定义元数据,看看它是否有效(可能会)