java/HrisniciSpameri/src/java/cz/frantovo/hrisniciSpameri/dao/GeneratorSouhrnuDAO.java
1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000
1.2 +++ b/java/HrisniciSpameri/src/java/cz/frantovo/hrisniciSpameri/dao/GeneratorSouhrnuDAO.java Sat Feb 14 14:27:53 2009 +0100
1.3 @@ -0,0 +1,75 @@
1.4 +package cz.frantovo.hrisniciSpameri.dao;
1.5 +
1.6 +import cz.frantovo.hrisniciSpameri.dto.Cil;
1.7 +import java.sql.Connection;
1.8 +import java.sql.Date;
1.9 +import java.sql.PreparedStatement;
1.10 +import java.sql.ResultSet;
1.11 +import java.util.Collection;
1.12 +import java.util.logging.Level;
1.13 +
1.14 +/**
1.15 + *
1.16 + * @author fiki
1.17 + */
1.18 +public class GeneratorSouhrnuDAO extends HrisniciSuperDAO {
1.19 +
1.20 + private enum SQL {
1.21 +
1.22 + VLOZ_SOUHRN
1.23 + }
1.24 +
1.25 + /**
1.26 + * Vygeneruje souhrn pro daný cíl a datum a uloží ho do databáze
1.27 + * @param cil cíl, pro který generujeme souhrn
1.28 + * @param den den, pro který souhrn generujeme.
1.29 + */
1.30 + private void generujSouhrn(Cil cil, Date den) {
1.31 + Connection dbZdroj = getSpojeni(cil.getDatabaze());
1.32 + Connection dbSouhrn = getSpojeni(null);
1.33 +
1.34 + if (dbZdroj == null || dbSouhrn == null) {
1.35 + /** TODO: Chyba spojení */
1.36 + } else {
1.37 + PreparedStatement ps = null;
1.38 + ResultSet rs = null;
1.39 + try {
1.40 + ps = dbZdroj.prepareStatement(cil.getSelekt());
1.41 + ps.setDate(1, den);
1.42 + rs = ps.executeQuery();
1.43 + PreparedStatement psSouhrn = dbSouhrn.prepareStatement(getSQL(SQL.VLOZ_SOUHRN));
1.44 + while (rs.next()) {
1.45 + /**
1.46 + * Souhrn bychom mohli vkládat pomocí SouhrnDAO,
1.47 + * ale z výkonnostních důvodů to budeme dělat tady
1.48 + * (jedno spojení a jeden předpřipravený příkaz).
1.49 + */
1.50 + psSouhrn.setDate(1, den);
1.51 + psSouhrn.setString(2, rs.getString("ip"));
1.52 + psSouhrn.setString(3, "TODO: přeložit " + rs.getString("ip"));
1.53 + psSouhrn.setInt(4, rs.getInt("pocet"));
1.54 + psSouhrn.setInt(5, cil.getId());
1.55 + psSouhrn.executeUpdate();
1.56 + }
1.57 + zavri(null, psSouhrn, null);
1.58 + dbSouhrn.commit();
1.59 + } catch (Exception e) {
1.60 + log.log(Level.SEVERE, "Chyba při generování souhrnu.", e);
1.61 + } finally {
1.62 + zavri(dbZdroj, ps, rs);
1.63 + zavri(dbSouhrn, null, null);
1.64 + }
1.65 + }
1.66 + }
1.67 +
1.68 + /**
1.69 + * Vygeneruje denní souhrny pro všechny cíle.
1.70 + * @param den den, pro který souhrny generujeme.
1.71 + */
1.72 + public void generujSouhrny(Date den) {
1.73 + Collection<Cil> cile = new CilDAO().getCile();
1.74 + for (Cil c : cile) {
1.75 + generujSouhrn(c, den);
1.76 + }
1.77 + }
1.78 +}