我正在研究使用内置分页功能的检票口数据表,其中数据是通过数据提供者提供的。Wicket NavigationToolbar 用于显示用于导航数据表页面的链接,如下所示
public class AbstractDataTable<T, S> extends DataTable<T, S> {
private static final long serialVersionUID = -3370089530205846951L;
public AbstractDataTable(String id, List<? extends IColumn<T, S>> columns, ISortableDataProvider<T, S> dataProvider) {
this(id, columns, dataProvider, DataTableConstants.DEFAULT_ELEMS_PER_PAGE);
}
public AbstractDataTable(String id, List<? extends IColumn<T, S>> columns, ISortableDataProvider<T, S> dataProvider,
int elemsPerPage) {
super(id, columns, dataProvider, elemsPerPage);
addToolbars(dataProvider);
}
protected void addToolbars(ISortableDataProvider<T, S> dataProvider) {
addTopToolbar(new HeadersToolbar<S>(this, dataProvider));
addBottomToolbar(new NavigationToolbar(this));
addBottomToolbar(new NoRecordsToolbar(this));
}
这里 dataprovider 保存要显示的全部数据,因此从数据库中获取全部数据需要很长时间。因此,为了避免这种情况,我计划以这样一种方式实现分页,即每次根据页面大小单击下一步按钮时调用数据库。基本上像下面这样
select * from table_name LIMIT 25 OFFSET ${req.query.pageNumber 25} 将记录数限制为 25。当 req.query.pageNumber=1 时,它将偏移前 25 条记录并发送接下来的 25 条记录。同样,如果 req.query.pageNumber=2,它将偏移前 2 25 条记录并发送 51-75 条记录。
卡在这里我正在寻找实现上述功能的方法
更新
数据提供者的骨架
public class DataTableProvider<T extends AbstractDataProvider> extends BaseProvider implements Serializable {
private static final long serialVersionUID = -6593326956377071200L;
private final List<T> searchResults;
public DataTableProvider() {
this(null);
}
public DataTableProvider(List<T> bo) {
this.searchResults = null != bo ? bo : new LinkedList<T>();
}
public List<T> provide() {
return searchResults;
}
public int size() {
return provide().size();
}
public void update(List<T> bos) {
searchResults.clear();
searchResults.addAll(null != bos ? bos : Collections.<T> emptyList());
}
public boolean isEmpty() {
return provide().isEmpty();
}
}
上面的数据提供者在点击搜索按钮时被填充
@Override
protected void onSubmit(SearchFilterBO criteria) {
if (getLog().isDebugEnabled()) {
getLog().debug(format(MSG_PTRN_SEARCH_SUBMISSION, ToStringBuilder.reflectionToString(criteria)));
}
getResultsProvider().update(searchService.searchBy(criteria));
getLog().info(format(MSG_PTRN_SEARCH_ENDED, getResultsProvider().size()));
}