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 Aug 04 23:55:30 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 +}