У меня возникла проблема с моим кодом, и я не могу ее выяснить.
Я пытаюсь заполнить jComboBox данными из SQLlite, а затем получить индекс выбранного элемента, чтобыЯ мог бы использовать его для дальнейшей деятельности.Я заполняю jComboBox, используя список массивов.
А вот код для списка массивов:
public ArrayList<Battery> batteries() throws Exception {
ArrayList<Battery> batteriesList = new ArrayList();
try {
Statement stmt = null;
Connection conn = null;
Battery currentBattery = null;
String url = "jdbc:sqlite:batteries.db";
conn = DriverManager.getConnection(url);
String sql = "Select * from batteries";
stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery(sql);
while (rs.next()) {
currentBattery = new Battery(rs.getString("companyName"), rs.getString("batteryType"), rs.getFloat("batteryVolt"), rs.getFloat("batteryAmp"));
batteriesList.add(currentBattery);
}
} catch (Exception e) {
JOptionPane.showMessageDialog(null, e);
}
return batteriesList;
}
Вот мой код для заполнения jComboBox:
public void showBatteries() {
ArrayList<Battery> list = null;
try {
list = batteries();
for (int i = 0; i < list.size(); i++) {
jComboBox_BatteryChooser.addItem(list.get(i).getCompanyName() + " " + list.get(i).getBatteryModel());
}
} catch (Exception ex) {
Logger.getLogger(mainWindow.class.getName()).log(Level.SEVERE, null, ex);
}
}
Чтобы получить индекс выбранного элемента, я 'используя это:
public void fillData(){
System.out.println("Index of item: "+jComboBox_BatteryChooser.getSelectedIndex());
}
Однако все время результат функции fillData () всегда равен 0. Не могли бы вы указать мне правильное направление или помочь мне решить эту проблему?Большое спасибо:)