JavaFX tableview bag на java, когда я анализирую и вводлю данные с sql - PullRequest
0 голосов
/ 20 февраля 2020

Просмотр таблицы не выводит полностью данные из таблицы sql, хотя ошибок нет. То есть проблема в том, что программа выводит только часть данных, хотя некоторые из них есть в самом листе

SQL класс запросов (sqlworker)

public List<String> gettableManagmet() throws SQLException {
    resSet = statmt.executeQuery("PRAGMA TABLE_INFO('Users');");
    List<String> ls = new ArrayList<>();

    while (resSet.next()) {
        ls.add(resSet.getString("name"));
    }
    System.out.println(ls);
    return ls;
}

    public ObservableList<Users> getdatausermanagment() throws SQLException {
    ObservableList<Users> res = FXCollections.observableArrayList();
        resSet = statmt.executeQuery("SELECT * FROM Users");
        while (resSet.next()) {
                String id = String.valueOf(resSet.getInt("id"));
                String Login = resSet.getString("Login");
                String Pass = resSet.getString("Pass");
                String Otel = resSet.getString("Otel");
                String isManager = String.valueOf(resSet.getInt("isManager"));
                String isAdmin  = String.valueOf(resSet.getInt("isAdmin"));
                String isBlocked = String.valueOf(resSet.getInt("isBlocked"));
                String CauseBlocking = resSet.getString("CauseBlocking");
                System.out.println(id+ Login+Pass+Otel+isManager+isAdmin+isAdmin+CauseBlocking);
            res.add(new Users(id,Login,Pass,Otel,isManager,isAdmin,isBlocked,CauseBlocking));
        }

        for(Users s : res){
                System.out.println(s);
        }
        return res;
}


public void adddata(TableView table) throws SQLException {
    ObservableList<Users> res = FXCollections.observableArrayList();
    resSet = statmt.executeQuery("SELECT * FROM Users");
    while (resSet.next()) {
        String id = String.valueOf(resSet.getInt("id"));
        String Login = resSet.getString("Login");
        String Pass = resSet.getString("Pass");
        String Otel = resSet.getString("Otel");
        String isManager = String.valueOf(resSet.getInt("isManager"));
        String isAdmin  = String.valueOf(resSet.getInt("isAdmin"));
        String isBlocked = String.valueOf(resSet.getInt("isBlocked"));
        String CauseBlocking = resSet.getString("CauseBlocking");
        System.out.println(id+ Login+Pass+Otel+isManager+isAdmin+isAdmin+isBlocked+CauseBlocking);
       table.getItems().add(new Users(id,Login,Pass,Otel,isManager,isAdmin,isBlocked,CauseBlocking));
    }
}

Класс пользователей

private final String id;
private final String login;
private final String pass;
private final String otel;
private SimpleStringProperty isManager;
private final String isAdmin;
private final String isBlocked;
private final String causeBloocking;

public Users(String id, String login, String pass, String otel, String isManager, String isAdmin, String isBlocked, String causeBlocking) {
this.id = id;
this.login = login;
this.pass = pass;
this.otel = otel;
this.isManager = new SimpleStringProperty(isManager);
this.isAdmin = isAdmin;
this.isBlocked  = isBlocked;
this.causeBloocking = causeBlocking;

}

public String getId() {
    return id;
}

public String getLogin() {
    return login;
}

public String getPass() {
    return pass;
}

public String getOtel() {
    return otel;
}

public String getisManager() {
    return isManager.get();
}

public String getisAdmin() {
    return isAdmin;
}

public String getisBlocked() {
    return isBlocked;
}

public String getCauseBloocking() {
    return causeBloocking;
}

Класс, в котором я анализирую данные

public TableView table;
@Override
public void initialize(URL location, ResourceBundle resources) {
    SQLWorker sqlWorker = new SQLWorker();
    table.setEditable(true);
    try {
        for (String s: sqlWorker.gettableManagmet()) {
            TableColumn<Users, String> tb = new TableColumn<>(s);
            tb.setCellValueFactory(new PropertyValueFactory<>(s));
            tb.setCellFactory(TextFieldTableCell.forTableColumn());
            tb.setVisible(true);
                            table.getColumns().addAll(tb);
            System.out.println(tb.getProperties());
        }

        System.out.println(table.getColumns().size());

      sqlWorker.adddata(table);



    } catch (SQLException e) {
        e.printStackTrace();
    }



}

f xml file

введите описание изображения здесь

когда программа в работе введите описание изображения здесь

sql база данных введите описание изображения здесь

1 Ответ

0 голосов
/ 20 февраля 2020

Проблемы здесь

  1. Вы не придерживаетесь Java соглашений об именах для 3 ваших получателей; PropertyValueFactory полагается на них: свойство, переданное конструктору, изменяется путем преобразования первой буквы в верхний регистр, а затем PropertyValueFactory проверяет методы с этим измененным именем с префиксом get или is. Например, он ищет getIsManager() или isIsManager(), а не getisManager(). (Обратите внимание, что это намного легче читать между прочим.)
  2. В одном из имен ваших получателей (и соответствующего поля) есть опечатка: это должно быть getCauseBlocking(), а не getCauseBloocking()
...