1

我有一个从数据库中获取数据的数据提供程序,并且我将我的数据保存为一个列表。

List<Person> myList= new ArrayList<>(dao.getAllPersons());
ListDataProvider<Person> dataProvider = new ListDataProvider<>(myList);
//...
grid.setDataProvider(dataProvider);

当我从数据库中删除一些数据时,它不会立即刷新。我必须刷新我的页面才能看到差异。

dao.deletePerson(...);
dataProvider.refreshAll();

refreshAll() 根本不起作用。我怎样才能刷新它?

4

1 回答 1

1

解决了。

dataProvider.getItems().remove(item); // Removed item from list
dao.deletePerson(...); // and removed it from my database too

在那之后:

 dataProvider.refreshAll();

编辑:

这不是最好的解决方案。

如果有一天内存消耗成为问题,您应该切换到自己的数据提供程序(例如,使用 fetch 和 count 回调)直接从数据库查询但分页。

@Steffen Harbich 的评论

于 2017-08-22T08:32:55.287 回答