Hibernate search method

本文介绍了一个基于Hibernate实现的新闻数据分页查询及搜索功能的具体代码实现。该实现包括了分页获取新闻列表、统计新闻总数以及按标题或内容模糊搜索新闻的功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    @SuppressWarnings("unchecked")
    public List<NewsBean> findNewsListByPaging(final int pageIndex,final int pageSize) {
        return (List<NewsBean>) getHibernateTemplate().execute( new HibernateCallback(){
            public Object doInHibernate(Session session) throws HibernateException, SQLException {
                return session.createQuery("FROM NewsBean n order by n.newsId").setFirstResult((pageIndex-1)*pageSize).setMaxResults(pageSize).list();
            }
        });
    }

    public Object findNewsCount() {
        return getHibernateTemplate().execute(new HibernateCallback(){
            public Object doInHibernate(Session session)throws HibernateException, SQLException {
                return session.createQuery("SELECT COUNT(*) FROM NewsBean").uniqueResult();
            }
        });
    }

    /* search news */
    @SuppressWarnings("unchecked")
    public List<NewsBean> selectNewsList(final NewsBean newsBean) {
        return (List<NewsBean>) getHibernateTemplate().execute(new HibernateCallback(){
            public Object doInHibernate(Session session)throws HibernateException, SQLException {
                Criteria qbc = session.createCriteria(NewsBean.class);
                if(null!=newsBean){
                    if(null!=newsBean.getNewsTitle() && !"".equals(newsBean.getNewsTitle().trim())){
                        qbc.add(Restrictions.like("newsTitle", newsBean.getNewsTitle(),MatchMode.ANYWHERE));
                    }
                    if(null!=newsBean.getContent() && !"".equals(newsBean.getContent().trim())){
                        qbc.add(Restrictions.like("content", newsBean.getContent(),MatchMode.ANYWHERE));
                    }
                }
                return qbc.list();
            }
        });
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值