我是爪哇的初学者。我确实需要从数组或ArrayList返回DefaultTableModel (javax.swing)。有可能吗?我无法将数组插入到DefaultTableModel (构造函数)中。
代码如下:
private DefaultListModel model;
public DefaultListModel getNamesAndIdToCombobox(Connection conn, boolean closeConn, String sql) throws SQLException {
long counter = 0;
try {
Statement stmt =
conn.prepareStatement(sql);
ResultSet rs = stmt.executeQuery(sql);
while (rs.next()) {
// String longKey = (String)rs.getString(2);
try
{
jListList.add(new JListValues(rs.getLong(2), rs.getString(1)));
}
catch(SQLException sqlException){}
try
{
jListList.add(new JListValues(rs.getLong(2), rs.getLong(1)));
}
catch(SQLException sqlException){}
try
{
jListList.add(new JListValues(rs.getString(2), rs.getLong(1)));
}
catch(SQLException sqlException){}
counter++;
}
JListValues[] array = jListList.toArray(new JListValues[jListList.size()]);
model = new DefaultListModel(array); // HERE IT IS A PROBLEM
LOGGER.info("getNamesAndIdToCombobox result count: " + counter);
} catch (SQLException e) {
LOGGER.error("Error", e);
throw e;
} finally {
try {
if (closeConn == true)
conn.close();
} catch (Exception e) {/* null */
}
}
return model;
}发布于 2013-10-03 03:25:09
添加以下代码以将数组列表值添加到DefaultListModel应该可以正常工作:
DefaultListModel<JListValues> model = new DefaultListModel<>()
for(JListValues val : array)
model.addElement(val);发布于 2014-09-10 04:40:06
使用下面的方法,不需要遍历数据集,效率要高得多。
JList<String> jlist = new JList<String>(new String[]{"a","b","c","d"});
DefaultListModel<String> defaultListModel = (DefaultListModel<String>)jlist.getModel();
ArrayList<String> arrayList = Collections.list(defaultListModel.elements());https://stackoverflow.com/questions/19144855
复制相似问题