java/sql-vyuka/src/java/cz/frantovo/sql/vyuka/dao/PruvodceDAO.java
changeset 37 e32867db5487
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/java/sql-vyuka/src/java/cz/frantovo/sql/vyuka/dao/PruvodceDAO.java	Tue Jun 02 00:27:15 2009 +0200
     1.3 @@ -0,0 +1,71 @@
     1.4 +package cz.frantovo.sql.vyuka.dao;
     1.5 +
     1.6 +import cz.frantovo.sql.vyuka.dto.Pruvodce;
     1.7 +import java.sql.Connection;
     1.8 +import java.sql.PreparedStatement;
     1.9 +import java.sql.ResultSet;
    1.10 +import java.util.logging.Level;
    1.11 +
    1.12 +/**
    1.13 + * Načítá průvodce (nápovědu) z databáze.
    1.14 + * @author fiki
    1.15 + */
    1.16 +public class PruvodceDAO extends VyukaSuperDAO {
    1.17 +
    1.18 +    private enum SQL {
    1.19 +
    1.20 +        PODLE_KODU,
    1.21 +        PODLE_ID,
    1.22 +        PODLE_ID_PREDCHOZI,
    1.23 +        PODLE_ID_NASLEDUJICI
    1.24 +    }
    1.25 +
    1.26 +    public Pruvodce getPruvodce(long id) {
    1.27 +        return getPruvodce(getSQL(SQL.PODLE_ID), id);
    1.28 +    }
    1.29 +
    1.30 +    public Pruvodce getPruvodce(String kod) {
    1.31 +        return getPruvodce(getSQL(SQL.PODLE_KODU), kod);
    1.32 +    }
    1.33 +
    1.34 +    public Pruvodce getPruvodcePredchozi(long id) {
    1.35 +        return getPruvodce(getSQL(SQL.PODLE_ID_PREDCHOZI), id);
    1.36 +    }
    1.37 +
    1.38 +    public Pruvodce getPruvodceNasledujici(long id) {
    1.39 +        return getPruvodce(getSQL(SQL.PODLE_ID_NASLEDUJICI), id);
    1.40 +    }
    1.41 +
    1.42 +    private Pruvodce getPruvodce(String selekt, Object... parametry) {
    1.43 +        Connection db = getSpojeni(DATABAZE.APLIKACE);
    1.44 +        if (db == null) {
    1.45 +            log.log(Level.SEVERE, "Databáze je null.");
    1.46 +            return null;
    1.47 +        } else {
    1.48 +            PreparedStatement ps = null;
    1.49 +            ResultSet rs = null;
    1.50 +            try {
    1.51 +                ps = db.prepareStatement(selekt);
    1.52 +                for (int i = 0; i < parametry.length; i++) {
    1.53 +                    ps.setObject(i + 1, parametry[i]);
    1.54 +                }
    1.55 +                rs = ps.executeQuery();
    1.56 +                if (rs.next()) {
    1.57 +                    Pruvodce p = new Pruvodce();
    1.58 +                    p.setId(rs.getLong("id"));
    1.59 +                    p.setKod(rs.getString("kod"));
    1.60 +                    p.setNadpis(rs.getString("nadpis"));
    1.61 +                    p.setObsah(rs.getString("obsah"));
    1.62 +                    return p;
    1.63 +                } else {
    1.64 +                    return null;
    1.65 +                }
    1.66 +            } catch (Exception e) {
    1.67 +                log.log(Level.SEVERE, "Chyba při hledání průvodce.", e);
    1.68 +                return null;
    1.69 +            } finally {
    1.70 +                zavri(db, ps, rs);
    1.71 +            }
    1.72 +        }
    1.73 +    }
    1.74 +}