我的tableview显示空白行

时间:2015-11-18 09:02:22

标签: mysql javafx tableview

我是JavaFX的新手,我一直在尝试实现此代码,以便在TableView中显示来自MySQL数据库的数据。问题是,当我运行代码时,我得到空行,我不知道为什么。

这是我的课程代码:

import java.io.IOException;
import java.net.URL;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.Statement;
import java.time.ZoneId;
import java.util.ArrayList;
import java.util.List;
import java.util.Optional;
import java.util.ResourceBundle;
import javafx.beans.property.SimpleIntegerProperty;
import javafx.beans.property.SimpleStringProperty;
import javafx.beans.property.StringProperty;
import javafx.collections.FXCollections;
import javafx.collections.ObservableList;
import javafx.event.ActionEvent;
import javafx.fxml.FXML;
import javafx.fxml.FXMLLoader;
import javafx.fxml.Initializable;
import javafx.scene.Node;
import javafx.scene.control.Alert;
import javafx.scene.control.Button;
import javafx.scene.control.ButtonType;
import javafx.scene.control.ComboBox;
import javafx.scene.control.DatePicker;
import javafx.scene.control.TableColumn;
import javafx.scene.control.TableView;
import javafx.scene.control.TextArea;
import javafx.scene.control.TextField;
import javafx.scene.control.cell.PropertyValueFactory;
import javafx.scene.layout.AnchorPane;
import javafx.stage.Stage;
import javax.swing.JOptionPane;

public class FXMLPatientsMasterController implements Initializable {

    /*
       mysql connection variables
    */
    Connection conn=null;
    PreparedStatement pat=null;
    ResultSet rs=null;
    private ObservableList<PatientDetails> patients;

     @FXML
     private TableView Table_Patients;

     @FXML
     private TableColumn patientID;

     @FXML
     private TableColumn Name;

     @FXML
     private TableColumn Surname;

     @FXML
     private TableColumn pnationalID;

     @FXML
     private TableColumn psex;

     @FXML
     private TableColumn pDOB;

      // Some code here

    @Override
    public void initialize(URL url, ResourceBundle rb) {
        // TODO
        conn = PMS263MySqlConnection.ConnectDB();

        try {                       
            patients = FXCollections.observableArrayList();
            rs = conn.createStatement().executeQuery("select * from     patients");
            while (rs.next()) {
                patients.add(new PatientDetails(rs.getInt("PatientId"),
                rs.getString("fName"), rs.getString("Surname"), rs.getString("National_ID"), rs.getString("Sex"), rs.getString("DOB")));
            }
            patientID.setCellValueFactory(new PropertyValueFactory("PatientId"));
            Name.setCellValueFactory(new PropertyValueFactory("fName"));
            Surname.setCellValueFactory(new PropertyValueFactory("Surname"));
            pnationalID.setCellValueFactory(new PropertyValueFactory("National_ID"));
            psex.setCellValueFactory(new PropertyValueFactory("Sex"));
            pDOB.setCellValueFactory(new PropertyValueFactory("DOB"));
            Table_Patients.setItems(null);
            Table_Patients.setItems(patients);         
        } catch (Exception e) {
            e.printStackTrace();
            System.out.println("Error on Building Data");
        }
    }

    public static class PatientDetails {
        private final SimpleIntegerProperty Patientid;
        private final StringProperty Pname;
        private final StringProperty Psurname;
        private final StringProperty Pnationalid;
        private final StringProperty Psex;
        private final StringProperty Pdob;
        private PatientDetails(int patientid, String pname, String psurname, String pnationalid, String psex, String pdob) {
            this.Patientid = new SimpleIntegerProperty(patientid);
            this.Pname = new SimpleStringProperty(pname);
            this.Psurname = new SimpleStringProperty(psurname);
            this.Pnationalid = new SimpleStringProperty(pnationalid);
            this.Psex= new SimpleStringProperty(psex);
            this.Pdob = new SimpleStringProperty(pdob);
        }

        public SimpleIntegerProperty patientidProperty() {
            return Patientid ;
        }

        public StringProperty pnameProperty() {
            return Pname;
        }

        public StringProperty psurnameProperty() {
            return Psurname;
        }

        public StringProperty pnationalidProperty() {
            return Pnationalid;
        }

        public StringProperty psexPsexProperty() {
            return Psex;
        }
        public StringProperty pdobProperty() {
            return Pdob;
        }
    }    
}    

1 个答案:

答案 0 :(得分:0)

假设您的数据库查询有效,则属性名称错误:

如果属性“getter”的名称为myNameProperty(),则需要使用new PropertyValueFactory("myName")

要么重命名属性“getters”,要么将值与工厂一起使用:

patientID.setCellValueFactory(new PropertyValueFactory("patientId"));
Name.setCellValueFactory(new PropertyValueFactory("pname"));
Surname.setCellValueFactory(new PropertyValueFactory("psurname"));
pnationalID.setCellValueFactory(new PropertyValueFactory("pnationalid"));
psex.setCellValueFactory(new PropertyValueFactory("psex"));
pDOB.setCellValueFactory(new PropertyValueFactory("pdob"));

...

    public SimpleIntegerProperty patientIdProperty() {
        return Patientid;
    }

    public StringProperty pnameProperty() {
        return Pname;
    }

    public StringProperty psurnameProperty() {
        return Psurname;
    }

    public StringProperty pnationalidProperty() {
        return Pnationalid;
    }

    public StringProperty psexProperty() {
        return Psex;
    }

    public StringProperty pdobProperty() {
        return Pdob;
    }