我知道通过setMaxResults& Hibernate中的Criteria的setFristResults方法我可以做分页..但我的问题是如何将它与DAO分开,我的意思是我只在那里实现DAO我能够指定setMaxResults()& setFristResults()值,我想把它作为一个单独的层,因为如果假设有大约500个DAO的各种模块,那么它很难相应地改变,
这是代码: 域名:
public class Demo implements java.io.Serializable {
private int id;
private Date date;
private String weekday;
private Double cost;
public Demo()
{
}
public Demo(Date date, String weekday, Double cost)
{
this.date = date;
this.weekday = weekday;
this.cost = cost;
}
/***Setter & getter***/
}
DAO:
public interface DemoDAO {
public void setPage(Page page);
public List<Demo> findAll();
}
public class DemoDAOImpl implements DemoDAO {
private HibernateDAO hibernateDAO;
private Session session;
private Page page;
public DemoDAOImpl()
{
hibernateDAO = new HibernateDAOImpl();
session = hibernateDAO.getSession();
}
public void setPage(Page page)
{
this.page = page;
}
public List<Demo> findAll()
{
session.beginTransaction();
Criteria criteria = session.createCriteria(Demo.class);
criteria.setFirstResult(page.getPageNumber() * page.getPageSize());
criteria.setMaxResults(page.getPageSize());
List<Demo> demoList = criteria.list();
session.getTransaction().commit();
return demoList;
}
服务:
public interface DemoService {
public List<Demo> showDetails(Page page);
}
public class DemoServiceImpl implements DemoService {
private DemoDAO demoDAO;
public DemoServiceImpl()
{
demoDAO = new DemoDAOImpl();
}
public List<Demo> showDetails(Page page)
{
if(page != null)
demoDAO.setPage(page);
else
page = new Page(0,50);
return demoDAO.findAll();
}
}
现在从前端我称之为showDetails ...
如果我使用正确的东西,请纠正我......
答案 0 :(得分:2)
你正在使你的DAO成为有状态的,而且那不太好。
您可以将Page
作为参数传递给每个方法。因此,DAO
的单个实例就足够了。