Hql语句查询

原创 2012年03月26日 14:21:01

返回一个值 如最大值,最小值

 

	/**
	 * 获取最早激活时间
	 */
	public String getStartDate() {
		// TODO Auto-generated method stub
		
		Session session=this.getSessionFactory().openSession();

		String hql="select min(activ_time) from  r_device_active " ;
		String list=new String();
		Object results=session.createSQLQuery(hql).uniqueResult();
		
		this.closeSession(session);
		//没有记录
		if(results == null || "".equals(results)){
			SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
			return sdf.format(new Date());
 
		}
		return results.toString();
	}


查询一个字段 ,返回一个list

/**
	 * 获取某条件下的激活时间
	 */
	public List<String> getActiveDate(String tradeognm,String custnm,String productdutyempnm,String productnm,String startDate,String endsDate ) {
		// TODO Auto-generated method stub
		Session session=this.getSessionFactory().openSession();
		String Hhql="";
		if(startDate != null && !"".equals(startDate) && !"null".equals(startDate)){
			Hhql += " and c.activ_time >='" + startDate + "'";
		}
		
		if(Hhql != null && !"".equals(endsDate) && !"null".equals(endsDate)){
				Hhql += " and c.activ_time <='" + endsDate + "'";
		}
		String hql=" select c.activ_time  from r_patternoutlist a" +
		" join r_product_info b on a.barcode=b.serial_no" +
		" join r_device_active c on c.mac=b.mac  where a .tradeognm='"+tradeognm +"'and a.custnm='"+custnm+"' and a.productdutyempnm ='"+productdutyempnm+"'and a.productnm ='"+productnm+"'"+Hhql;
		
		
		
		List<String> list=new ArrayList<String>();
		//results 定义一个list Object
		List<Object> results=session.createSQLQuery(hql).list();
		try{

			for(Object obj:results){
				int i=0;
				list.add(SimpleTools.CNull(obj).toString());
			}
		}catch(Exception e){
			e.printStackTrace();
		}
		this.closeSession(session);
		return list;
	}



查询多个字段 ,返回一个list

   

    /**
     * 获取工贸-门店-产品代表-型号
     */
	public List<ManchineOpenedJson> getManchineOpenedJsonList(Page reportPage,HashMap<String, Object> param) {
		// TODO Auto-generated method stub
		Session session=this.getSessionFactory().openSession();
		
		
		//工贸
		String trade = (String)param.get("trade");
		//门店
		String store = (String)param.get("store");
		//产品代表
		String productDuty = (String)param.get("productDuty");
		//产品型号
		String product = (String)param.get("product");
		
		//开始时间
		String startDate = (String)param.get("startDate");
		//结束时间
		String endDate = (String)param.get("endDate");
		
		String queryHql = "";
		//查询条件
		if(trade != null && !"".equals(trade) && !"null".equals(trade)){
			queryHql += "and tradeognm='" + trade + "'";
		}
		
		if(store != null && !"".equals(store) && !"null".equals(store)){
			 
				queryHql += " and custnm='" + store + "'";
		 
		}
		if(productDuty != null && !"".equals(productDuty) && !"null".equals(productDuty)){
			 
				queryHql += " and productdutyempnm='" + productDuty + "'";
			 
		}
		if(product != null && !"".equals(product) && !"null".equals(product)){
			 
				queryHql+= " and productnm='" + product + "'";
			 
		}
		
		if(startDate != null && !"".equals(startDate) && !"null".equals(startDate)){
			queryHql += " and c.activ_time >='" + startDate + "'";
		}
		
		if(endDate != null && !"".equals(endDate) && !"null".equals(endDate)){
				queryHql += " and c.activ_time <='" + endDate + "'";
		}
		
		String hql="select tradeognm, custnm,productdutyempnm, productnm,count(barcode) " +
				"from r_patternoutlist a " +
				" join r_product_info b on a.barcode=b.serial_no "+
				"join r_device_active c on c.mac=b.mac "+
				"where 1=1 " +queryHql+
				" group by(tradeognm, custnm,productdutyempnm, productnm) order by tradeognm asc";
		List<ManchineOpenedJson> list=new ArrayList<ManchineOpenedJson>();
		//results 定义一个list Object[]
		List<Object[]> results=session.createSQLQuery(hql).list();
		
		
		//设置总记录数
		reportPage.setRecordCount(results.size());
		//需要分页
		if(reportPage.isIfPage()){
			int start = (reportPage.getCurrentPage() - 1) * reportPage.getPageSize();
			int end   = (reportPage.getCurrentPage()) * reportPage.getPageSize(); 
			if(end > results.size()){
				end = results.size();
			}
			try{
				results = results.subList(start, end);
			}catch(Exception e){
				
			}
		}

		ManchineOpenedJson m;
		
		for(Object[] obj:results){
			m=new ManchineOpenedJson();
			int i=0;
			//将查询字段 放到javaBean中
			m.setTrade(obj[i].toString());
			m.setStore(SimpleTools.CNull(obj[++i]));
			m.setProductDuty(SimpleTools.CNull(obj[++i]));
			m.setProduct(SimpleTools.CNull(obj[++i]));
			m.setActiveSum(SimpleTools.CNull(obj[++i]));
			list.add(m);
		}

		this.closeSession(session);
		return list;
	}


                    

hql精点查询语句.doc

  • 2012年07月27日 10:47
  • 47KB
  • 下载

hibernate 中HQL语句查询学习笔记

  • 2009年05月25日 12:26
  • 353KB
  • 下载

hibernate--HQL查询语句-----分组、排序--多条件排序

1.实体的更新和删除:   在继续讲解HQL其他更为强大的查询功能前,我们先来讲解以下利用HQL进行实体更新和删除的技术。这项技术功能是Hibernate3的新加入的功能,在Hibernate2中...

hql语句查询

  • 2016年07月25日 16:28
  • 2.73MB
  • 下载

HQL语句查询

  • 2014年12月24日 14:47
  • 162KB
  • 下载

常用的一些HQL查询语句详解(3)

(1)from Topic t where t.msgs is not empty 详解:empty:意思是空的,not empty:非空的  意思是取出 msgs不是空值的Topic内容; (2)...

HQL语句(实例查询)

  • 2010年01月11日 11:55
  • 39KB
  • 下载

HQL.pdf数据查询语句

  • 2015年09月25日 09:11
  • 346KB
  • 下载

hibernate--HQL查询语句(1)

本章介绍了Hibernate的几种主要检索方式:HQL检索方式、QBC检索方式、SQL检索方式。HQL是Hibernate Query Language的缩写,是官方推荐的查询语言。QBC是Query...

hql查询语句

  • 2013年05月24日 22:23
  • 39KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Hql语句查询
举报原因:
原因补充:

(最多只允许输入30个字)