Należy użyć funkcji paginacji zewnętrznej. Najpierw określ w tagu HTML, czy używasz stronicowania zewnętrznego. I stwórz obiekt implementujący org.displaytag.pagination.PaginatedList. Na koniec musisz zaimplementować DAO, które faktycznie tworzy zapytanie tylko dla 15 wierszy i zwraca PaginatedList.
1) Twój JSP będzie wyglądać następująco
<display:table name="command" sort="external" partialList="true" size="${command.fullListSize}" pagesize="${command.objectsPerPage}">
<display:column property="name" title="name"/>
...
</display:table>
pamiętać, że określony rodzaj jest zewnętrzny.
2) org.displaytag.pagination.PopinatedList implementation.
public class PaginatedListImpl<T> implements PaginatedList{
private int fullListSize;
private int objectsPerPage;
private int pageNumber;
private String searchId;
private String sortCriterion;
private SortOrderEnum sortDirection;
private List<T> list;
//getters and setters
...
}
3) Próbka wdrożenia DAO za pomocą hibernacji. Możesz to zrobić za pomocą JDBC lub cokolwiek innego, ale upewnij się, że tworzysz właściwe zapytanie, aby uzyskać 15 wierszy we właściwej kolejności i zwróć obiekt PaginatedListImpl.
@SuppressWarnings("unchecked")
public PaginatedListImpl<T> getPaginatedList(PaginatedListImpl paginatedList) {
int pageNum = paginatedList.getPageNumber();
final int objectsPerPage = paginatedList.getObjectsPerPage();
final int firstResult = objectsPerPage * pageNum;
String sortOrderCriterion = pagiantedList.getSortOrderCriterion();
String sortOrder = paginatedList.getSortOrder
String className = type.getName().substring(type.getName().lastIndexOf(".") + 1);
final StringBuilder fromClause = new StringBuilder("from " + className + " " + alias);
String orderByClause = new StringBuilder(" order by ").append(sortCriterion).append(" ").append(sortDirection);
final String hql = new StringBuilder().append(fromClause).append(orderClause).toString();
List<T> resultList = getHibernateTemplate().executeFind(new HibernateCallback() {
public Object doInHibernate(Session session) throws HibernateException, SQLException {
return session.createQuery(hql)
.setFirstResult(firstResult)
.setMaxResults(objectsPerPage)
.list();
}
});
Long count = (Long)getHibernateTemplate().execute(new HibernateCallback() {
public Object doInHibernate(Session session) throws HibernateException, SQLException {
return session.createQuery("select count(*) " + fromClause).uniqueResult();
}
});
paginatedList.setFullListSize(count.intValue());
paginatedList.setList(resultList);
paginatedList.setPageNumber(pageNum+1);
paginatedList.setObjectsPerPage(objectsPerPage);
return paginatedList;
}
gdzie to sprawdzić? – Sayan