Gam*_*ijo 2 java javafx tableview
当我想在 javafx 中向 tableview 添加数据时,我收到此错误
java.lang.ClassCastException:java.util.ArrayList无法转换为javafx.collections.ObservableList
用户类
public class User {
private int id;
private String nom;
private String prenom;
private String cin;
private String tel;
private String adresse;
private String dn;
Run Code Online (Sandbox Code Playgroud)
和功能数据:
public ArrayList afficher_user() throws SQLException{
ArrayList<User> data = new ArrayList<>();
Connection conn=null;
try {
Class.forName(Driver);
conn = DriverManager.getConnection(URL,"root","");
String sql ="select * from utilisateur";
PreparedStatement Stmt = conn.prepareStatement(sql);
ResultSet rs = Stmt.executeQuery(sql);
while(rs.next()){
User us = new User();
us.setId(rs.getInt("id"));
us.setNom(rs.getString("nom"));
us.setPrenom(rs.getString("prenom"));
us.setCin(rs.getString("cin"));
us.setAdresse(rs.getString("adresse"));
us.setTel(rs.getString("tel"));
us.setDn(rs.getString("dn"));
data.add(us);
}
rs.close();
conn.close();
} catch (ClassNotFoundException ex) {
System.err.println(ex.getMessage());
}
return data;
}
Run Code Online (Sandbox Code Playgroud)
在控制器类中:
private TableView<User> dgv_user;
@FXML
private TableColumn<User,String> id;
private TableColumn<User, String> nom;
private TableColumn<User, String> prenom;
private TableColumn<User, String> cin;
private TableColumn<User, String> dn;
private TableColumn<User, String> tel;
private TableColumn<User,String> adresse;
public void creer_user(ActionEvent event) throws SQLException {
User u=new User();
System.out.println(u.afficher_user());
dgv_user.setItems((ObservableList<User>) u.afficher_user());
}
Run Code Online (Sandbox Code Playgroud)
您不能直接将ArrayList
对象转换为observableList
,而是需要FXCollections.observableArrayList()
按以下代码所示使用并将其设置list
为您的dgv_user
对象。
ObservableList<User> observableArrayList =
FXCollections.observableArrayList(u.afficher_user());
dgv_user.setItems(observableArrayList);
Run Code Online (Sandbox Code Playgroud)