派生自 projectDept/qhighschool

EricsHu
2022-12-05 068fc7f2e81178e55fa191a13709af64b1a163f6
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
/******************************************************************************
 * Copyright (C) 2015 Shenzhen Penguin Network Technology Co., Ltd
 * All Rights Reserved.
 * 本软件为深圳市企鹅网络科技有限公司开发研制。未经本公司正式书面同意,其他任何个人、团体
 * 不得使用、复制、修改或发布本软件.
 *****************************************************************************/
 
package com.qxueyou.scc.school.dao;
 
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
 
import org.hibernate.SessionFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.orm.hibernate4.support.HibernateDaoSupport;
import org.springframework.stereotype.Repository;
 
 
@Repository(value="interactDAO")
/**
 * 自动注入sessionFactory 互动
 *
 * @author 邓志永
 * @since JDK1.6
 * @history 2015-01-07 邓志永 新建
 */
public class InteractDAO extends HibernateDaoSupport {
    
    /**
     * 注入sessionFactory
     *
     * @param sessionFactory
     */
    @Autowired(required = false)
    public void setSessionfactory(SessionFactory sessionFactory) {
        this.setSessionFactory(sessionFactory);
    }
    
    /**
     * 查询互动练习结果
     * @param hql
     * @param args
     * @return
     */
    @SuppressWarnings("unchecked")
    public List<Map<String, Object>> queryResultByInteractExer(String hql,
        List<Object> args) {
        // 查询结果
        List<Object[]> lst = (List<Object[]>) this.getHibernateTemplate().find(hql, args.toArray());
        if(lst.isEmpty()){
            return null;
        }
        List<Map<String, Object>> resultLst = new ArrayList<Map<String, Object>>(lst.size());
        
        Map<String, Object> resultMap = new HashMap<String, Object>(3);
        for (Object[] obj : lst) {
             resultMap = new HashMap<String, Object>();
             resultMap.put("name", obj[0]);
             resultMap.put("count", obj[1]);
             resultMap.put("peopleCount", obj[2]);//总人数
             resultLst.add(resultMap);
        }
        return resultLst;
    }
    
}