java/HrisniciSpameri/src/java/cz/frantovo/hrisniciSpameri/dao/GeneratorSouhrnuDAO.java
1 package cz.frantovo.hrisniciSpameri.dao;
3 import cz.frantovo.hrisniciSpameri.dto.Cil;
4 import java.net.InetAddress;
5 import java.sql.Connection;
7 import java.sql.PreparedStatement;
8 import java.sql.ResultSet;
9 import java.util.Collection;
10 import java.util.logging.Level;
16 public class GeneratorSouhrnuDAO extends HrisniciSuperDAO {
25 * Vygeneruje souhrn pro daný cíl a datum a uloží ho do databáze
26 * @param cil cíl, pro který generujeme souhrn
27 * @param den den, pro který souhrn generujeme.
29 public void generujSouhrn(Cil cil, Date zacatek, Date konec) {
30 Connection dbZdroj = getSpojeni(cil.getDatabaze());
31 Connection dbSouhrn = getSpojeni(null);
37 if (dbZdroj == null || dbSouhrn == null) {
38 /** TODO: Chyba spojení */
40 PreparedStatement ps = null;
41 PreparedStatement psSmazat = null;
44 /** pokud už něco vygenerovaného pro daný den a cíl máme, smažeme to */
45 psSmazat = dbSouhrn.prepareStatement(getSQL(SQL.SMAZ_SOUHRNY));
46 psSmazat.setInt(1, cil.getId());
47 psSmazat.setDate(2, zacatek);
48 psSmazat.setDate(3, konec);
49 psSmazat.executeUpdate();
51 ps = dbZdroj.prepareStatement(cil.getSelekt());
52 ps.setDate(1, zacatek);
54 rs = ps.executeQuery();
55 PreparedStatement psSouhrn = dbSouhrn.prepareStatement(getSQL(SQL.VLOZ_SOUHRN));
58 * Souhrn bychom mohli vkládat pomocí SouhrnDAO,
59 * ale z výkonnostních důvodů to budeme dělat tady
60 * (jedno spojení a jeden předpřipravený příkaz).
62 psSouhrn.setDate(1, rs.getDate("den"));
63 psSouhrn.setString(2, rs.getString("ip"));
64 psSouhrn.setString(3, prelozIP(rs.getString("ip")));
65 psSouhrn.setInt(4, rs.getInt("pocet"));
66 psSouhrn.setInt(5, cil.getId());
67 psSouhrn.executeUpdate();
69 zavri(null, psSouhrn, null);
71 } catch (Exception e) {
72 log.log(Level.SEVERE, "Chyba při generování souhrnu.", e);
74 zavri(dbZdroj, ps, rs);
75 zavri(dbSouhrn, psSmazat, null);
81 * Vygeneruje denní souhrny pro všechny cíle za dané období.
82 * @param zacatek začátek období – včetně
83 * @param konec konec období – včetně
85 public void generujSouhrny(Date zacatek, Date konec) {
86 Collection<Cil> cile = new CilDAO().getCile();
88 generujSouhrn(c, zacatek, konec);
93 * Přeloží IP adresu na doménu
97 private static String prelozIP(String ip) {
99 return InetAddress.getByName(ip).getHostName();
100 } catch (Exception e) {
101 return "Chyba: nepodařilo se přeložit.";