Swing JTable 动态SQL语句查询
写了无数次了,保存起来下次不重写了。每执行一次查询更新一次table的表头和表行数据。
private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) {// GEN-FIRST:event_jButton1ActionPerformed
ResultSet rs = DBUtil.executeQuery(textField1.getText());//执行SQL语句
// jTable1 = new JTable();
try {
List<List<Object>> ls = new ArrayList<List<Object>>();
List<String> column = new ArrayList<String>();
ResultSetMetaData rsm = rs.getMetaData();//获取表元数据
for (int i = 1; i < rsm.getColumnCount()+1; i++) {
column.add(rsm.getColumnName(i));
}
while (rs.next()) {
List<Object> result = new ArrayList<Object>();
for (int i = 1; i < rsm.getColumnCount()+1; i++) {
result.add(rs.getObject(i));
}
ls.add(result);
}
Object[][] obj = new Object[ls.size()][column.size()];
for (int i = 0; i < ls.size(); i++) {
List<Object> a = ls.get(i);
for (int j = 0; j < column.size(); j++) {
System.out.println(a.get(j));
obj[i][j] = a.get(j);
}
}
jTable1.setModel(new DefaultTableModel(obj,column.toArray(new String[column.size()])));
} catch (Exception e) {
e.printStackTrace();
}
}