Таблица не обновляется - PullRequest
       20

Таблица не обновляется

0 голосов
/ 18 октября 2011

У меня есть таблица, состоящая из строк отчетов. Метод обратного компонента, связанный с событием изменения значения флажка, получает идентификаторы строк и заполняет массив (rowToBeRemoved) этими идентификаторами. Другой метод получает этот массив и удаляет объект из класса reportlist:

ObjectListDataProvider reportList = new ObjectListDataProvider();
List<RowKey> rowsToBeRemoved=new ArrayList();
Integer rowsToBeRemovedIndex = 0;

 for(RowKey rowToBeRemoved:rowsToBeRemoved){

            try {                
                System.out.println("rowToBeRemoved.toString()" + rowToBeRemoved.toString()); // outputs: rowToBeRemoved.toString()RowKey[0] 

                Report report = (Report) reportList.getObject(rowToBeRemoved);

                System.out.println("report.getId()" + report.getId()); //outputs: report.getId()199|


                Query resultQuery = queryGeneration(report.getId());
                List<String> dropTableQueries = resultQuery.getResultList(); // generated the queries to drop r tables


                for(int i=0; i<dropTableQueries.size(); i++){

                   String aDropTableQuery;
                   aDropTableQuery = dropTableQueries.get(i);
                    System.out.println("adroptableuery" + aDropTableQuery);// get single drop table query. outputs adroptableueryDROP TABLE r_199_0
                   entityManager.createNativeQuery(aDropTableQuery);
                    System.out.println("entitymanager dropTableQueries is invoked");//OK
                   reportList.removeObject(rowToBeRemoved);
                    System.out.println("removeObject");//OK
                    if (reportList.isRemoved(rowToBeRemoved)){
                        System.out.println("object removed");//OK
                    }                    
                    reportList.commitChanges();
                    System.out.println("commitchanges");//OK

               }
                reportJpaController.delete(report);
                reportList.removeRow(rowToBeRemoved);
                reportList.commitChanges();
                analyzerResultService.drop(report.getId().longValue());
                //rowsToBeRemoved.remove(rowsToBeRemovedIndex);
            } catch (Exception e) {
                error("Cannot delete report with row key " + rowToBeRemoved + e);
            }

Код выполняется нормально, удаляет объект из списка отчетов, но после этого моя таблица вызывает смешанный список отчетов. Если я обновляю страницу, она приводит список отчетов в правильном порядке, иначе это не так. И если я пытаюсь удалить строку в смешанном состоянии, он удаляет отчет, как если бы он находился в правильном порядке, и заканчивает тем, что удаляет неправильный отчет. Я надеюсь, что смог объяснить .. Что я делаю не так?

1 Ответ

2 голосов
/ 18 октября 2011

Я думаю, что это похоже на то, что вы ищете: Как обновить всю страницу JSF из базового компонента

Это не просто обновляет одну часть страницы, нополная страница.

...