spring date jpa 中返回map类型的方法

来源:互联网 发布:马良中国软件下载 编辑:程序博客网 时间:2024/06/16 13:59

查找网上的资料,总结出两种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();(使用这个方法会报错..所以还是只有第一种方法能正常使用,希望知道的大神出来指正一下.)
阅读全文
0 0
原创粉丝点击