java/HrisniciSpameri/src/java/cz/frantovo/hrisniciSpameri/dao/GeneratorSouhrnuDAO.java
author František Kučera <franta-hg@frantovo.cz>
Sat, 14 Feb 2009 14:27:53 +0100
changeset 22 571d37e53ecd
child 23 b22c06c8a55c
permissions -rw-r--r--
Základ generátoru souhrnů
franta-hg@22
     1
package cz.frantovo.hrisniciSpameri.dao;
franta-hg@22
     2
franta-hg@22
     3
import cz.frantovo.hrisniciSpameri.dto.Cil;
franta-hg@22
     4
import java.sql.Connection;
franta-hg@22
     5
import java.sql.Date;
franta-hg@22
     6
import java.sql.PreparedStatement;
franta-hg@22
     7
import java.sql.ResultSet;
franta-hg@22
     8
import java.util.Collection;
franta-hg@22
     9
import java.util.logging.Level;
franta-hg@22
    10
franta-hg@22
    11
/**
franta-hg@22
    12
 *
franta-hg@22
    13
 * @author fiki
franta-hg@22
    14
 */
franta-hg@22
    15
public class GeneratorSouhrnuDAO extends HrisniciSuperDAO {
franta-hg@22
    16
franta-hg@22
    17
    private enum SQL {
franta-hg@22
    18
franta-hg@22
    19
        VLOZ_SOUHRN
franta-hg@22
    20
    }
franta-hg@22
    21
franta-hg@22
    22
    /**
franta-hg@22
    23
     * Vygeneruje souhrn pro daný cíl a datum a uloží ho do databáze
franta-hg@22
    24
     * @param cil cíl, pro který generujeme souhrn
franta-hg@22
    25
     * @param den den, pro který souhrn generujeme.
franta-hg@22
    26
     */
franta-hg@22
    27
    private void generujSouhrn(Cil cil, Date den) {
franta-hg@22
    28
        Connection dbZdroj = getSpojeni(cil.getDatabaze());
franta-hg@22
    29
        Connection dbSouhrn = getSpojeni(null);
franta-hg@22
    30
franta-hg@22
    31
        if (dbZdroj == null || dbSouhrn == null) {
franta-hg@22
    32
            /** TODO: Chyba spojení */
franta-hg@22
    33
        } else {
franta-hg@22
    34
            PreparedStatement ps = null;
franta-hg@22
    35
            ResultSet rs = null;
franta-hg@22
    36
            try {
franta-hg@22
    37
                ps = dbZdroj.prepareStatement(cil.getSelekt());
franta-hg@22
    38
                ps.setDate(1, den);
franta-hg@22
    39
                rs = ps.executeQuery();
franta-hg@22
    40
                PreparedStatement psSouhrn = dbSouhrn.prepareStatement(getSQL(SQL.VLOZ_SOUHRN));
franta-hg@22
    41
                while (rs.next()) {
franta-hg@22
    42
                    /**
franta-hg@22
    43
                     * Souhrn bychom mohli vkládat pomocí SouhrnDAO,
franta-hg@22
    44
                     * ale z výkonnostních důvodů to budeme dělat tady
franta-hg@22
    45
                     * (jedno spojení a jeden předpřipravený příkaz).
franta-hg@22
    46
                     */
franta-hg@22
    47
                    psSouhrn.setDate(1, den);
franta-hg@22
    48
                    psSouhrn.setString(2, rs.getString("ip"));
franta-hg@22
    49
                    psSouhrn.setString(3, "TODO: přeložit " + rs.getString("ip"));
franta-hg@22
    50
                    psSouhrn.setInt(4, rs.getInt("pocet"));
franta-hg@22
    51
                    psSouhrn.setInt(5, cil.getId());
franta-hg@22
    52
                    psSouhrn.executeUpdate();
franta-hg@22
    53
                }
franta-hg@22
    54
                zavri(null, psSouhrn, null);
franta-hg@22
    55
                dbSouhrn.commit();
franta-hg@22
    56
            } catch (Exception e) {
franta-hg@22
    57
                log.log(Level.SEVERE, "Chyba při generování souhrnu.", e);
franta-hg@22
    58
            } finally {
franta-hg@22
    59
                zavri(dbZdroj, ps, rs);
franta-hg@22
    60
                zavri(dbSouhrn, null, null);
franta-hg@22
    61
            }
franta-hg@22
    62
        }
franta-hg@22
    63
    }
franta-hg@22
    64
franta-hg@22
    65
    /**
franta-hg@22
    66
     * Vygeneruje denní souhrny pro všechny cíle.
franta-hg@22
    67
     * @param den den, pro který souhrny generujeme.
franta-hg@22
    68
     */
franta-hg@22
    69
    public void generujSouhrny(Date den) {
franta-hg@22
    70
        Collection<Cil> cile = new CilDAO().getCile();
franta-hg@22
    71
        for (Cil c : cile) {
franta-hg@22
    72
            generujSouhrn(c, den);
franta-hg@22
    73
        }
franta-hg@22
    74
    }
franta-hg@22
    75
}