gpt4 book ai didi

java - 使用javaFx TableView 显示选定行的内容

转载 作者:行者123 更新时间:2023-12-02 13:11:47 25 4
gpt4 key购买 nike

我有一个 javafx 表,我希望显示在不同表单上单击的任何行的内容。下面是我尝试使用的方法,它没有给出预期的响应,尽管在我的 SceneBuilder 中,我将此方法添加到了 MouseClicked 事件中。

public void selectedRow() throws SQLException{
int row = studentTable.getSelectionModel().getSelectedIndex();
String sql = "select * from student where id= '" + row + "'";
pst = conn.prepareStatement(sql);
rs = pst.executeQuery();
if (rs.next()) {
String add1 = rs.getString("school_name");
System.out.println("The selected row is ==> "+ add1);
}
}

注意:我曾经使用 Jframe 尝试过类似的操作,它在我的 Jframe 中给了我预期的响应...这是完成工作所使用的方法。

private void all_storesMouseClicked(java.awt.event.MouseEvent evt) {                                        
// TODO add your handling code here:
try {
int row = studentTable.getSelectedRow();
String stores_click = (studentTable.getModel().getValueAt(row, 0)).toString();
String sql = "select * from student where id= '" + stores_click + "'";
pst = conn.prepareStatement(sql);
rs = pst.executeQuery();
if (rs.next()) {
String add1 = rs.getString("school_name");
System.out.println("The selected row is ==> "+ add1);
}
}

我会很感激如何解决这个问题。非常感谢您的宝贵时间。

最佳答案

你需要做的只是利用 split 方法来获取你选择的行的索引,这是什么意思。

String values = String.valueOf(studentTable.getSelectionModel().getSelectedItem());
String row = values.toString().split(",")[0].substring(1);

因此,在上面的函数中,下面的一些调整将为您完成工作。

public void selectedRow() throws SQLException{
String values =
String.valueOf(studentTable.getSelectionModel().getSelectedItem());
String row = values.toString().split(",")[0].substring(1);
String sql = "select * from student where id= '" + row + "'";
pst = conn.prepareStatement(sql);
rs = pst.executeQuery();
if (rs.next()) {
String add1 = rs.getString("school_name");
System.out.println("The selected row is ==> "+ add1);
}
}

我希望你明白我在那里解释的内容。

关于java - 使用javaFx TableView 显示选定行的内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43930554/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com