/[projects]/android/TrainInfoService/src/dk/thoerup/traininfoservice/SavedStatistics.java
ViewVC logotype

Annotation of /android/TrainInfoService/src/dk/thoerup/traininfoservice/SavedStatistics.java

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1400 - (hide annotations) (download)
Thu Apr 28 18:50:24 2011 UTC (13 years, 1 month ago) by torben
File size: 3498 byte(s)
show 5 busiest days
1 torben 961 package dk.thoerup.traininfoservice;
2    
3    
4     import java.io.IOException;
5     import java.sql.Connection;
6     import java.sql.ResultSet;
7     import java.sql.SQLException;
8     import java.sql.Statement;
9     import java.util.ArrayList;
10     import java.util.List;
11    
12     import javax.servlet.ServletException;
13     import javax.servlet.annotation.WebServlet;
14     import javax.servlet.http.HttpServlet;
15     import javax.servlet.http.HttpServletRequest;
16     import javax.servlet.http.HttpServletResponse;
17    
18 torben 1255 import dk.thoerup.traininfoservice.db.DBConnection;
19 torben 961
20 torben 1255
21 torben 961 @WebServlet(urlPatterns={"/SavedStatistics"})
22     public class SavedStatistics extends HttpServlet {
23     private static final long serialVersionUID = 1L;
24    
25    
26     protected SavedStatBean convertRow(ResultSet res) throws SQLException {
27     SavedStatBean bean = new SavedStatBean();
28    
29 torben 964 bean.label = res.getString(1);
30 torben 961 bean.station = res.getString(2);
31     bean.location = res.getString(3);
32     bean.name = res.getString(4);
33     bean.favorites = res.getString(5);
34     bean.departure = res.getString(6);
35     bean.depcache = res.getString(7);
36     bean.deperror = res.getString(8);
37     bean.timetable = res.getString(9);
38     bean.timecache = res.getString(10);
39     bean.timeerror = res.getString(11);
40    
41     return bean;
42    
43     }
44    
45 torben 1400 List<SavedStatBean> convertResultset(ResultSet res) throws SQLException{
46     List<SavedStatBean> stats = new ArrayList<SavedStatBean>();
47     while (res.next()) {
48     SavedStatBean bean = convertRow(res);
49     stats.add(bean);
50    
51     }
52     return stats;
53     }
54 torben 961
55 torben 1400
56 torben 961 protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
57    
58     Connection conn = null;
59     try {
60     conn = DBConnection.getConnection();
61     Statement stmt = conn.createStatement();
62    
63    
64 torben 1400
65    
66 torben 961 String sqlAvg = "SELECT count(*) AS count, round(avg(location+name+favorites),1) AS station, round(avg(location),1) as location, round(avg(name),1) as name, round(avg(favorites),1) as favorites, " +
67     "round(avg(departure),1) as departure, round(avg(depcache),1) as depcache, round(avg(deperror),1) as deperror, " +
68     "round(avg(timetable),1) as timetable, round(avg(timecache),1) as timecache, round(avg(timeerror),1) as timeerror " +
69 torben 968 "FROM trainstatistics " +
70     "WHERE statisticsdate <> now()::date ";
71 torben 961
72     ResultSet resAvg = stmt.executeQuery(sqlAvg);
73     resAvg.next();
74     SavedStatBean avgBean = convertRow(resAvg);
75    
76     ////////////////////////////////////////////////
77    
78     String SQL = "SELECT statisticsdate, location+name+favorites AS station, location,name,favorites,departure,depcache,deperror,timetable,timecache,timeerror " +
79     "FROM trainstatistics ORDER BY statisticsdate DESC limit 14";
80    
81    
82     ResultSet res = stmt.executeQuery(SQL);
83 torben 1400 List<SavedStatBean> stats = convertResultset(res);
84 torben 961
85 torben 1400
86     //////////////////////////////////////////////
87 torben 961
88 torben 1400 SQL = "select statisticsdate,location+name+favorites AS station,location,name,favorites,departure,depcache,deperror,timetable,timecache,timeerror from trainstatistics order by departure - deperror desc limit 5";
89     res = stmt.executeQuery(SQL);
90 torben 961
91 torben 1400 List<SavedStatBean> top5 = convertResultset(res);
92 torben 967
93 torben 1400
94 torben 967 conn.close();
95 torben 961
96    
97 torben 962 request.setAttribute("avg", avgBean);
98 torben 961 request.setAttribute("stats", stats);
99 torben 1400 request.setAttribute("top5", top5);
100 torben 961 request.getRequestDispatcher("/savedstatistics.jsp").forward(request, response);
101    
102    
103     } catch (SQLException e) {
104     try {
105     if (conn != null) conn.close();
106     } catch (SQLException se) {}
107     throw new ServletException(e);
108     }
109     }
110    
111     }

  ViewVC Help
Powered by ViewVC 1.1.20