hibernate使用criteria进行子查询并分页

背景:

有一张活动表(volunteer_activity)

和一张活动报名表(volunteer_sign_up)–存放志愿者活动报名记录

要求:查出志愿者参加的活动和未参加的活动

代码:

    /**
     * 查询已加入的活动
     * @param key
     * @param setPageSize
     * @return
     */
    @Override
    public PageBean findAllVolunteerJoinActivity(String key, PageBean<VolunteerActivityEntity> setPageSize, String userId) {

        Session session = sessionFactory.openSession();

        /**
         * hibernate 利用子查询实现 exists 功能
         */
        Criteria criteria = session.createCriteria(VolunteerActivityEntity.class, "activity");
        DetachedCriteria detachedCriteria = DetachedCriteria.forClass(VolunteerSignUpEntity.class,"signUp");
        detachedCriteria.add(Restrictions.eq("volunteerId", userId));
        detachedCriteria.add(Property.forName("activity.activityId").eqProperty("signUp.activityId"));
        criteria.add(Subqueries.exists(detachedCriteria.setProjection(Projections.property("signUp.signUpId"))));//这里改为notExists就是查询未参加的活动了

        if (key != null && !key.equals("")) {
            //搜索
            List list = criteria.add(
                    Restrictions.or(
                            Restrictions.or(Restrictions.like("activityCode", key, MatchMode.ANYWHERE)),
                            Restrictions.or(Restrictions.like("activityTitle", key, MatchMode.ANYWHERE)),
                            Restrictions.or(Restrictions.like("activityContent", key, MatchMode.ANYWHERE)),
                            Restrictions.or(Restrictions.like("activityLeader", key, MatchMode.ANYWHERE))))
                    .setFirstResult((setPageSize.getCurrPage() - 1) * setPageSize.getPageSize() )
                    .setMaxResults((setPageSize.getCurrPage() - 1) * setPageSize.getPageSize() + setPageSize.getPageSize()).list();
            setPageSize.setRows(list);
        } else {
            setPageSize.setRows(criteria.setFirstResult((setPageSize.getCurrPage() - 1) * setPageSize.getPageSize())
                    .setMaxResults((setPageSize.getCurrPage() - 1) * setPageSize.getPageSize() + setPageSize.getPageSize()).setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY).list());
        }

        session.close();

        return setPageSize;
    }

 

查询结果:

Hibernate: 
    select
        this_.activity_id as activity1_3_0_,
        this_.activity_code as activity2_3_0_,
        this_.activity_content as activity3_3_0_,
        this_.activity_end_time as activity4_3_0_,
        this_.activity_leader as activity5_3_0_,
        this_.activity_people_num as activity6_3_0_,
        this_.activity_sign_end_time as activity7_3_0_,
        this_.activity_sign_start_time as activity8_3_0_,
        this_.activity_start_time as activity9_3_0_,
        this_.activity_title as activit10_3_0_ 
    from
        volunteer_activity this_ 
    where
        exists (
            select
                signUp_.sign_up_id as y0_ 
            from
                volunteer_sign_up signUp_ 
            where
                signUp_.volunteer_id=? 
                and this_.activity_id=signUp_.activity_id
        ) limit ?
View Code

 

转载于:https://www.cnblogs.com/HuangJie-sol/p/11017895.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值