我试图编写一个代码,当用户点击“按名称排序”按钮时,我的程序将对我的数据库的记录进行排序并将它们放入JTable中,将2个DB表与INNER JOIN组合在一起。我已经设法通过使用resultSet并选择例如Ascending Order来完成此操作。但是因为我不想拥有2个按钮,一个用于ASC,一个用于DESC,我想到了使用preparedStatement和一个showInputDialog,用户将在其中选择是否要进行ASC或DESC排序并执行订单。另外,我记得我见过的一些程序使用了一个功能,当你第一次点击按钮时它会对DESC进行排序,如果再次按下它会被ASC命令(没有设法在WEB上找到)。关于我的第一个想,我试着这样做,但我可以通过这个
ResultSetMetaData mdsort = rssort.getMetaData();
我应该有一个ResultSet变量(rssort)来使用getMetaData()但是如果我选择用我的PreparedStatement制作程序,我会在那里得到一个错误。有什么建议??
try{
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost/test1?user=me&password=12345");
Statement stmtsort = conn.createStatement();
ResultSet rssort = stmtsort.executeQuery("SELECT * FROM consoles INNER JOIN hardware ON consoles.id=hardware.id ORDER BY consoles.name ASC");
// ERROR HERE!!! needs resultset,not preparedStatement
ResultSetMetaData mdsort = rssort.getMetaData();
columnCount = mdsort.getColumnCount();
String[] colssort = new String[columnCount];
for (i=1;i<= columnCount;i++)
{
colssort[i-1] = mdsort.getColumnName(i);
}
DefaultTableModel model = new DefaultTableModel(colssort,0);
while (rssort.next())
{
Object[] rowsort = new Object[columnCount];
for (i = 1 ; i <= columnCount ; i++)
{
rowsort[i-1] = rssort.getObject(i);
}
model.addRow(rowsort);
}
JTable table = new JTable(model);
model.fireTableDataChanged();
table.setCellSelectionEnabled(true);
table.setColumnSelectionAllowed(true);
table.setFillsViewportHeight(true);
table.setSurrendersFocusOnKeystroke(true);
table.setBounds(218,59,529,360);
frame.getContentPane().add(table);
model.fireTableDataChanged();
conn.close();
stmtsort.close();
rssort.close();
} catch (SQLException case1)
{case1.printStackTrace();
} catch (Exception case2)
{case2.printStackTrace();}
}
});
更新
好的我设法用getMetaData()解决了这个问题,但现在问题是我不使用任何ResultSet变量/实例,并且不能使用next()方法来创建我的数据库。
String name = "SELECT * FROM consoles INNER JOIN hardware ON consoles.id=hardware.id ORDER BY consoles.name ?";
PreparedStatement psname = conn.prepareStatement(name);
String strin = JOptionPane.showInputDialog(null,"ASC or DESC order ? : ");
psname.setString(1,strin);
psname.executeUpdate();
ResultSetMetaData mdsort = psname.getMetaData();
int columnCount = mdsort.getColumnCount();
.
.
.
// error coming up here,because i deleted the ResultSet
while (psname.next())
.
.
.
答案 0 :(得分:2)
最好使TableModel更复杂。
这是更优化的。
将ResultSet中的数据保存在原始TableModel中。 使用包装TableModel进行排序,也可以过滤。
对于列类型使用ResultSetMetaData,如果它是Number(Integer,BigDecimal,...),则对列类型使用该类型而不是Object:给出右对齐列。
也许首先在网上搜索ResultSetTableModel;其他人必须已经做到了。
答案 1 :(得分:0)
try{
conn = DriverManager.getConnection("jdbc:mysql://localhost/test1?user=me&password=12345");
String strin = JOptionPane.showInputDialog(null,"ASC or DESC order ? : ");
stmtsortname = conn.createStatement();
rssortname = stmtsortname.executeQuery("SELECT * FROM consoles INNER JOIN hardware ON consoles.id=hardware.id ORDER BY consoles.name "+strin);
mdsortname = rssortname.getMetaData();
columnCount = mdsortname.getColumnCount();
String[] colssortname = new String[columnCount];
for (i=1;i<= columnCount;i++)
{
colssortname[i-1] = mdsortname.getColumnName(i);
}
model = new DefaultTableModel(colssortname,0);
while (rssortname.next())
{
Object[] rowsortname = new Object[columnCount];
for (i = 1 ; i <= columnCount ; i++)
{
rowsortname[i-1] = rssortname.getObject(i);
}
model.addRow(rowsortname);
}
table = new JTable(model);
model.fireTableDataChanged();
table.setCellSelectionEnabled(true);
table.setColumnSelectionAllowed(true)
table.setFillsViewportHeight(true);
table.setSurrendersFocusOnKeystroke(true);
table.setBounds(146,59,763,360);
frame.getContentPane().add(table);
model.fireTableDataChanged();
conn.close();
stmtsortname.close();
rssortname.close();
} catch (SQLException case1)
{
case1.printStackTrace();
}
catch (Exception case2)
{
case2.printStackTrace();
}
}
});