Hibernate HQL查询中对日期的查询操作总结

@Override
	public int getCount(PlanSearchCriteria criteria) throws Exception {
		StringBuilder hql = new StringBuilder();
		hql.append("SELECT COUNT(*) FROM Plan plan ");

		Map<String,Object> parameters = new HashMap<String,Object>();
         
		hql.append(" WHERE 1 = 1 ");
		
		if(StringUtils.isNotEmpty(criteria.getPlanStatus())) {
			hql.append(" AND plan.planStatus = :planStatus ");
			parameters.put("planStatus", PlanStatus.valueOf(criteria.getPlanStatus()));
		}
		if(StringUtils.isNotEmpty(criteria.getPlanType())) {
			hql.append(" AND plan.planType = :planType ");
			parameters.put("planType", PlanType.valueOf(criteria.getPlanType()));
		}
		if(StringUtils.isNotEmpty(criteria.getNoticeTime())) {
			hql.append(" AND to_char(plan.notice.noticeTime,'yyyy-MM-dd') = :noticeTime" );
			parameters.put("noticeTime", criteria.getNoticeTime());
		}
		

		Query query = getSession().createQuery(hql.toString());

		return ((Long) setParameter(query,parameters).uniqueResult())
				.intValue();
	}


	private Query setParameter(Query query,Map<String,Object> parameters) {
		if(parameters.get("planStatus") != null) {
			query.setParameter("planStatus", parameters.get("planStatus"));
		}
		if(parameters.get("planType") != null) {
			query.setParameter("planType", parameters.get("planType"));
		}
		if(parameters.get("noticeTime") != null) {
			query.setParameter("noticeTime", parameters.get("noticeTime"));
		}
		return query;
	}


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值