You need to store data; that what you call an "intermediate class") will be the data type for yours TableView.
, , - , . , List<String> :
TableView<List<String>> unitsTableView = new TableView<>();
idUnit = new TableColumn<List<String>, String>("Id");
idUnit.setCellValueFactory(new Callback<CellDataFeatures<List<String>, String>, ObservableValue<String>>() {
@Override
public ObservableValue<String> call(CellDataFeatures<List<String>, String>> data) {
return new ReadOnlyStringWrapper(data.getValue().get(0)) ;
}
});
shortNameUnit = new TableColumn<List<String>, String>("Short Name");
shortNameUnit.setCellValueFactory(new Callback<CellDataFeatures<List<String>, String>, ObservableValue<String>>() {
@Override
public ObservableValue<String> call(CellDataFeatures<List<String>, String>> data) {
return new ReadOnlyStringWrapper(data.getValue().get(1)) ;
}
});
nameUnit = new TableColumn<List<String>, String>("Name");
nameUnit.setCellValueFactory(new Callback<CellDataFeatures<List<String>, String>, ObservableValue<String>>() {
@Override
public ObservableValue<String> call(CellDataFeatures<List<String>, String>> data) {
return new ReadOnlyStringWrapper(data.getValue().get(2)) ;
}
});
public static ObservableList<List<String>> getUnits() {
final ObservableList<List<String>> data = FXCollections.observableArrayList();
if (openConnection()) {
try {
rs = st.executeQuery("SELECT * FROM units");
while (rs.next()) {
List<String> unit = new ArrayList<>();
unit.add(rs.getString("id_unit"));
unit.add(rs.getString("short_name"));
unit.add(rs.getString("name"));
data.add(unit);
}
} catch (Exception ex) {
Logger.getLogger(SQLConnect.class.getName()).log(Level.SEVERE, null, ex);
}
}
closeConnection();
return data;
}
, .
, ResultSet , . -, TableView . ResultSet , List - ( 5 ...). , ResultSet (, , , JDBC) . , , TableView .
?