hibernate的一个分页的写法

本文提供了一个基于Hibernate的Java方法实现,该方法用于按条件分页查询投票集合。当请求参数为空时,设置默认的页面大小及当前页数。通过构建SQL查询语句并使用动态SQL来增加查询条件,最后执行分页查询。

直接上代码:

// 按条件分页查询投票集合
    public List<Subject> getSubjectList(String title, Integer pageNumber,
            Integer pageSize) {
        if(pageNumber==null){
            pageNumber = 1;
        }
        if(pageSize==null){
            pageSize =5;
        }
        Session session = null;
        List<Subject> list = null;
        try {
            session = HibernateUtil.currentSession();
            StringBuffer hql = new StringBuffer("select s.sid,s.title," +
                    "(select count(*) from Option o where o.subject.sid=s.sid)," +
                    "(select count(distinct user.uid) from Item i where i.subject.sid=s.sid)" +
                    "from Subject s where 1=1");
            if (title != null) {
                hql.append(" and s.title like '%"+title+"%'");
            }
            hql.append(" order by s.sid desc");
            Query query = session.createQuery(hql.toString());
            query.setFirstResult((pageNumber-1) * pageSize);
            query.setMaxResults(pageSize);      
            list = query.list();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return list;
    }

别的不说了。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值