查找网上的资料,总结出两种spring date jpa 中使用sql查询返回出map的方法
StringBuffer hql = new StringBuffer();
hql.append(" SELECT COUNT(c.id) waitPayOrder,COUNT(d.id) allOrder ");
hql.append(" FROM (SELECT id FROM my_order WHERE create_date >= DATE_FORMAT(NOW(),'%Y-%m-%d') ");
hql.append(" AND create_date <= DATE_FORMAT(DATE_SUB(NOW(),INTERVAL - 1 DAY),'%Y-%m-%d') ");
hql.append(" AND order_status = 1) c RIGHT JOIN (SELECT id FROM my_order ");
hql.append(" WHERE create_date >= DATE_FORMAT(NOW(),'%Y-%m-%d') AND ");
hql.append(" create_date <= DATE_FORMAT(DATE_SUB(NOW(),INTERVAL - 1 DAY),'%Y-%m-%d')) d ON c.id = d.id ");
Query query = em.createNativeQuery(hql.toString());
query.unwrap(SQLQuery.class).setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
@SuppressWarnings("unchecked")
List<Map<String, Object>> rows = query.getResultList();
这种方法会返回一个map的集合..但网上说的这种方法会损失一定的性能..所以看着情况而定吧.
第二种(网上的说法,但使用时没有成功):
Query query = em.createNativeQuery(hql.toString(),Map.class);
Map<Stirng,Object> map = query.getHints();(使用这个方法返回的结果是null,不知道是不是用错了)
List<Map<String, Object>> rows = query.getResultList();(使用这个方法会报错..所以还是只有第一种方法能正常使用,希望知道的大神出来指正一下.)