2016-06-21 2 views
0

Im чистый новичок. Я сделал свой стол, добавив столбцы из базы данных с итерации:setOnEditCommit с итерацией JavaFX

public void captureDataSuper() { 
    Connection c; 
    ObservableList<ObservableList> data; 
    data = FXCollections.observableArrayList(); 
    try { 
     c = KonekDB.createConnection(); 
     //SQL FOR SELECTING ALL OF CUSTOMER 
     String SQL = "SELECT * from adminsupervisor"; 
     //ResultSet 
     ResultSet rs = c.createStatement().executeQuery(SQL); 

     /** 
     * ******************************** 
     * TABLE COLUMN ADDED DYNAMICALLY * ******************************** 
     */ 
     for (int i = 0; i < rs.getMetaData().getColumnCount(); i++) { 
      //We are using non property style for making dynamic table 
      final int j = i; 
      TableColumn col = new TableColumn(rs.getMetaData().getColumnName(i + 1)); 
      //now its editable 
      col.setCellFactory(TextFieldTableCell.<Adminsupervisor>forTableColumn()); 
      //trying to make effect on database after edited with setOnEditCommit 
      col.setOnEditCommit(
        new EventHandler<CellEditEvent<Adminsupervisor, String>>() { 

       public void handle(CellEditEvent<Adminsupervisor, String> t) { 
        ((Adminsupervisor) t.getTableView().getItems().get(
          t.getTablePosition().getRow())).set(j, t.getNewValue()); 
       } 
      } 
      ); 
      col.setCellValueFactory(new Callback<CellDataFeatures<ObservableList, String>, ObservableValue<String>>() { 
       public ObservableValue<String> call(CellDataFeatures<ObservableList, String> param) { 
        return new SimpleStringProperty(param.getValue().get(j).toString()); 
       } 
      }); 

      supervisorTable.getColumns().addAll(col); 
      System.out.println("Column [" + i + "] "); 
     } 

     /** 
     * ****************************** 
     * Data added to ObservableList * ****************************** 
     */ 
     while (rs.next()) { 
      //Iterate Row 
      ObservableList<String> row = FXCollections.observableArrayList(); 
      for (int i = 1; i <= rs.getMetaData().getColumnCount(); i++) { 
       //Iterate Column 
       row.add(rs.getString(i)); 
      } 
      System.out.println("Row [1] added " + row); 
      data.add(row); 

     } 

     //FINALLY ADDED TO TableView 
     supervisorTable.setItems(data); 
    } catch (Exception e) { 
     e.printStackTrace(); 
     System.out.println("Error on Building Data"); 
    } 
    } 

Как вы можете видеть, мой setOnEditCommit был совершенно не смысл:

col.setOnEditCommit(
       new EventHandler<CellEditEvent<Adminsupervisor, String>>() { 

      public void handle(CellEditEvent<Adminsupervisor, String> t) { 
       ((Adminsupervisor) t.getTableView().getItems().get(
         t.getTablePosition().getRow())).set(j, t.getNewValue()); 
      } 
     } 
     ); 

Это модель класса Adminsupervisor:

public class Adminsupervisor { 

private String id; 
private String username; 
private String password; 
private String userType; 

public String getId() { 
    return id; 
} 

public String getUsername() { 
    return username; 
} 

public String getPassword() { 
    return password; 
} 

public String getUserType() { 
    return userType; 
} 

public void setId(String id) { 
    this.id = id; 
} 

public void setUsername(String username) { 
    this.username = username; 
} 

public void setPassword(String password) { 
    this.password = password; 
} 

public void setUserType(String userType) { 
    this.userType = userType; 
} 

void set(int j, String newValue) { 
    for (j = 0; j < 4; j++) { 
     if (j == 0) { 
      setId(newValue); 
     } 
     if (j == 2) { 
      setPassword(newValue); 
     } 
     if (j == 3) { 
      setUserType(newValue); 
     } 
     if (j == 1) { 
      setUsername(newValue); 
     } 
    } 
    try { 
     Connection c = KonekDB.createConnection(); 

     String SQL = "UPDATE adminsupervisor SET " 
       + "username=" + username + "," 
       + "password=" + password + "," 
       + "userType=" + userType + " WHERE id=" + id + ""; 
     //ResultSet 
     c.createStatement().executeUpdate(SQL); 
    } catch (Exception e) { 
     e.printStackTrace(); 
     System.out.println("Error on Building Data"); 
    } 
}} 

Я получил эту трассировку стека:

Exception in thread "JavaFX Application Thread" java.lang.ClassCastException: com.sun.javafx.collections.ObservableListWrapper cannot be cast to AdminSide.Adminsupervisor 
at AdminSide.PanelAdmin$1.handle(PanelAdmin.java:275) 
at AdminSide.PanelAdmin$1.handle(PanelAdmin.java:272) 
at com.sun.javafx.event.CompositeEventHandler.dispatchBubblingEvent(CompositeEventHandler.java:86) 
at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:238) 
at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:191) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:58) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.EventUtil.fireEventImpl(EventUtil.java:74) 
at com.sun.javafx.event.EventUtil.fireEvent(EventUtil.java:49) 
at javafx.event.Event.fireEvent(Event.java:198) 
at javafx.scene.control.TableCell.commitEdit(TableCell.java:349) 
at javafx.scene.control.cell.CellUtils.lambda$createTextField$615(CellUtils.java:248) 
at com.sun.javafx.event.CompositeEventHandler.dispatchBubblingEvent(CompositeEventHandler.java:86) 
at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:238) 
at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:191) 
at com.sun.javafx.event.CompositeEventDispatcher.dispatchBubblingEvent(CompositeEventDispatcher.java:59) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:58) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.EventUtil.fireEventImpl(EventUtil.java:74) 
at com.sun.javafx.event.EventUtil.fireEvent(EventUtil.java:49) 
at javafx.event.Event.fireEvent(Event.java:198) 
at javafx.scene.Node.fireEvent(Node.java:8411) 
at com.sun.javafx.scene.control.behavior.TextFieldBehavior.fire(TextFieldBehavior.java:179) 
at com.sun.javafx.scene.control.behavior.TextInputControlBehavior.callAction(TextInputControlBehavior.java:178) 
at com.sun.javafx.scene.control.behavior.BehaviorBase.callActionForEvent(BehaviorBase.java:218) 
at com.sun.javafx.scene.control.behavior.TextInputControlBehavior.callActionForEvent(TextInputControlBehavior.java:127) 
at com.sun.javafx.scene.control.behavior.BehaviorBase.lambda$new$74(BehaviorBase.java:135) 
at com.sun.javafx.event.CompositeEventHandler$NormalEventHandlerRecord.handleBubblingEvent(CompositeEventHandler.java:218) 
at com.sun.javafx.event.CompositeEventHandler.dispatchBubblingEvent(CompositeEventHandler.java:80) 
at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:238) 
at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:191) 
at com.sun.javafx.event.CompositeEventDispatcher.dispatchBubblingEvent(CompositeEventDispatcher.java:59) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:58) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.EventUtil.fireEventImpl(EventUtil.java:74) 
at com.sun.javafx.event.EventUtil.fireEvent(EventUtil.java:54) 
at javafx.event.Event.fireEvent(Event.java:198) 
at javafx.scene.Scene$KeyHandler.process(Scene.java:3964) 
at javafx.scene.Scene$KeyHandler.access$1800(Scene.java:3910) 
at javafx.scene.Scene.impl_processKeyEvent(Scene.java:2040) 
at javafx.scene.Scene$ScenePeerListener.keyEvent(Scene.java:2501) 
at com.sun.javafx.tk.quantum.GlassViewEventHandler$KeyEventNotification.run(GlassViewEventHandler.java:197) 
at com.sun.javafx.tk.quantum.GlassViewEventHandler$KeyEventNotification.run(GlassViewEventHandler.java:147) 
at java.security.AccessController.doPrivileged(Native Method) 
at com.sun.javafx.tk.quantum.GlassViewEventHandler.lambda$handleKeyEvent$353(GlassViewEventHandler.java:228) 
at com.sun.javafx.tk.quantum.QuantumToolkit.runWithoutRenderLock(QuantumToolkit.java:389) 
at com.sun.javafx.tk.quantum.GlassViewEventHandler.handleKeyEvent(GlassViewEventHandler.java:227) 
at com.sun.glass.ui.View.handleKeyEvent(View.java:546) 
at com.sun.glass.ui.View.notifyKey(View.java:966) 
at com.sun.glass.ui.win.WinApplication._runLoop(Native Method) 
at com.sun.glass.ui.win.WinApplication.lambda$null$148(WinApplication.java:191) 
at java.lang.Thread.run(Thread.java:745) 

Так что моя ячейка не сделала бы ничего после того, как будет изменено редактирование.

+0

взглянуть на ваш StackTrace и первую строчку говоря, что вы пытаетесь бросить «ObservableListWrapper» в ваш класс modell "AdminSide.Adminsupervisor".Вы уверены, что ваш объект DATA является наблюдаемым списком ObservableList или вы хотите иметь ObservableList AdminSide.Adminsupervisor? 'ObservableList '? – SSchuette

+1

@SSchuette yes Я хочу, чтобы Adminsupervisor был тем же типом, что и ObservableList, поэтому я могу без проблем обернуть его. Не могли бы вы рассказать мне, что делать? –

+0

«Я хочу сделать« Adminsupervisor »тем же типом, что и« ObservableList »? Это (очень) разные типы - вы не можете просто притворяться, что они одно и то же. Вам нужно решить, какой тип представлен каждой строкой таблицы, и придерживаться его. Если вы хотите, чтобы он был «Adminsupervisor», тогда сделайте 'data'' ObservableList 'и добавьте к нему соответствующие объекты. Если вы хотите, чтобы он был «ObservableList» (должен быть «ObservableList '), тогда полностью удалить класс «Adminsupervisor» и просто работать с «ObservableList». Первый лучше, имхо, но вам нужно выбрать его. –

ответ

1

data объявлен как ObservableList<ObservableList> data; и вы заполните его ObservableList с:

while (rs.next()) { 
    //Iterate Row 
    ObservableList<String> row = FXCollections.observableArrayList(); 
    ... 
    data.add(row); 
} 

В onEditCommit обработчике вы сделаете это, однако:

public void handle(CellEditEvent<Adminsupervisor, String> t) { 
    ((Adminsupervisor) t.getTableView().getItems().get(
      t.getTablePosition().getRow())).set(j, t.getNewValue()); 
} 

t.getTableView().getItems().get(index) возвращает ObservableList, который вы пытаетесь бросить до Adminsupervisor, который по понятным причинам не работает ...

Вам нужно использовать тот же тип для элементов и в обработчике. Если вы хотите использовать ObservableList или Adminsupervisor до вас ...

Примечание: Добавить параметры типа в TableView и TableColumn, и компилятор должен жаловаться на это. Однако, используя необработанные типы, вы не позволяете компилятору выполнять эти проверки (вы можете получить предупреждение о необработанных типах).

Кроме

for (j = 0; j < 4; j++) { 
    if (j == 0) { 
     setId(newValue); 
    } 
    if (j == 2) { 
     setPassword(newValue); 
    } 
    if (j == 3) { 
     setUserType(newValue); 
    } 
    if (j == 1) { 
     setUsername(newValue); 
    } 
} 

должен быть rewrittern, как

setId(newValue); 
setUsername(newValue); 
setPassword(newValue); 
setUserType(newValue); 

j = 4; // not really neccessary since there is no read access to j 

По крайней мере, тот же эффект. (А может быть, вы просто добавили for петлю вокруг этих if с без причины, и она должна быть удалена.)

А также рассмотреть возможность удаления j в качестве параметра из метода Adminsupervisor.set поскольку значение никогда не используется в методе (в оригинале версия перезаписывается 0, прежде чем любой доступ для чтения произойдет в for (j = 0; j < 4; j++), а в улучшенной версии он вообще не читается).

Кроме того, ObservableValue, возвращенный cellValueFactory, никогда не приведет к обновлению. Если вы используете ObservableList как тип элемента, вы можете использовать Bindings класс, чтобы получить ObservableValue для конкретного индекса:

col.setCellValueFactory(new Callback<CellDataFeatures<ObservableList, String>, ObservableValue<String>>() { 
    public ObservableValue<String> call(CellDataFeatures<ObservableList, String> param) { 
     return Bindings.stringValueAt(param.getValue(), j); 
    } 
}); 
+0

Спасибо, мистер, но мне нужно решение не суждение. –

+1

@SuryaHardiansyah: Затем просто добавьте 'Adminsupervisor' как элементы или, напротив, вместо« ObservableList ». Я думал, что это будет довольно очевидно, когда проблема будет объяснена ... – fabian

+0

как это сделать мистер? : «( , пожалуйста, скажите мне код, который я должен вставить между –

Смежные вопросы