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 den) {
30 Connection dbZdroj = getSpojeni(cil.getDatabaze());
31 Connection dbSouhrn = getSpojeni(null);
33 if (dbZdroj == null || dbSouhrn == null) {
34 /** TODO: Chyba spojení */
36 PreparedStatement ps = null;
37 PreparedStatement psSmazat = null;
40 log.log(Level.SEVERE, "AUTOCOMIT: " + dbSouhrn.getAutoCommit());
41 dbSouhrn.setAutoCommit(false);
43 /** pokud už něco vygenerovaného pro daný den a cíl máme, smažeme to */
44 psSmazat = dbSouhrn.prepareStatement(getSQL(SQL.SMAZ_SOUHRNY));
45 psSmazat.setInt(1, cil.getId());
46 psSmazat.setDate(2, den);
47 psSmazat.executeUpdate();
49 ps = dbZdroj.prepareStatement(cil.getSelekt());
51 rs = ps.executeQuery();
52 PreparedStatement psSouhrn = dbSouhrn.prepareStatement(getSQL(SQL.VLOZ_SOUHRN));
55 * Souhrn bychom mohli vkládat pomocí SouhrnDAO,
56 * ale z výkonnostních důvodů to budeme dělat tady
57 * (jedno spojení a jeden předpřipravený příkaz).
59 psSouhrn.setDate(1, den);
60 psSouhrn.setString(2, rs.getString("ip"));
61 psSouhrn.setString(3, prelozIP(rs.getString("ip")));
62 psSouhrn.setInt(4, rs.getInt("pocet"));
63 psSouhrn.setInt(5, cil.getId());
64 psSouhrn.executeUpdate();
66 zavri(null, psSouhrn, null);
68 } catch (Exception e) {
69 log.log(Level.SEVERE, "Chyba při generování souhrnu.", e);
71 zavri(dbZdroj, ps, rs);
72 zavri(dbSouhrn, psSmazat, null);
78 * Vygeneruje denní souhrny pro všechny cíle.
79 * @param den den, pro který souhrny generujeme.
81 public void generujSouhrny(Date den) {
83 den = SouhrnDAO.getVychoziDen();
86 Collection<Cil> cile = new CilDAO().getCile();
88 generujSouhrn(c, den);
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.";