java/sql-vyuka/src/java/cz/frantovo/sql/vyuka/dao/PiskovisteDAO.java
changeset 16 9acb74ac7346
child 17 08cd160ec1c6
     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/PiskovisteDAO.java	Fri May 29 03:44:35 2009 +0200
     1.3 @@ -0,0 +1,91 @@
     1.4 +package cz.frantovo.sql.vyuka.dao;
     1.5 +
     1.6 +import cz.frantovo.sql.vyuka.dao.VyukaSuperDAO.DATABAZE;
     1.7 +import cz.frantovo.sql.vyuka.dto.Hlaska;
     1.8 +import cz.frantovo.sql.vyuka.dto.Hlaska.Typ;
     1.9 +import cz.frantovo.sql.vyuka.dto.Tabulka;
    1.10 +import cz.frantovo.sql.vyuka.dto.Uzivatel;
    1.11 +import cz.frantovo.sql.vyuka.dto.VysledekSQL;
    1.12 +import java.sql.Connection;
    1.13 +import java.sql.PreparedStatement;
    1.14 +import java.sql.ResultSet;
    1.15 +import java.sql.SQLException;
    1.16 +import java.util.logging.Level;
    1.17 +
    1.18 +/**
    1.19 + * Pro spouštění uživatelových příkazů.
    1.20 + * @author fiki
    1.21 + */
    1.22 +public class PiskovisteDAO extends VyukaSuperDAO {
    1.23 +
    1.24 +    TipyDAO tipy = new TipyDAO();
    1.25 +    HistorieDAO historie = new HistorieDAO();
    1.26 +
    1.27 +    public VysledekSQL vykonejSQL(String sql, Uzivatel uzivatel) {
    1.28 +        VysledekSQL v = new VysledekSQL();
    1.29 +        if (historie.ulozPrikaz(sql, uzivatel)) {
    1.30 +
    1.31 +
    1.32 +
    1.33 +
    1.34 +
    1.35 +
    1.36 +            Tabulka t = new Tabulka();
    1.37 +
    1.38 +
    1.39 +
    1.40 +            Connection db = getSpojeni(DATABAZE.PISKOVISTE);
    1.41 +            if (db == null) {
    1.42 +                v.getHlasky().add(new Hlaska("Došlo k chybě spojení.", Typ.Chyba));
    1.43 +            } else {
    1.44 +                PreparedStatement ps = null;
    1.45 +                ResultSet rs = null;
    1.46 +                try {
    1.47 +                    ps = db.prepareStatement(sql);
    1.48 +                    rs = ps.executeQuery();
    1.49 +
    1.50 +                    int pocetSloupecku = rs.getMetaData().getColumnCount();
    1.51 +                    String[] zahlavi = new String[pocetSloupecku];
    1.52 +                    t.setZahlavi(zahlavi);
    1.53 +                    for (int i = 0; i < pocetSloupecku; i++) {
    1.54 +                        zahlavi[i] = rs.getMetaData().getColumnName(i + 1);
    1.55 +                    }
    1.56 +
    1.57 +                    while (rs.next()) {
    1.58 +                        Object[] hodnoty = new Object[pocetSloupecku];
    1.59 +                        for (int i = 0; i < pocetSloupecku; i++) {
    1.60 +                            hodnoty[i] = rs.getObject(i + 1);
    1.61 +                        }
    1.62 +                        t.getHodnoty().add(hodnoty);
    1.63 +                    }
    1.64 +
    1.65 +                    if (t.getHodnoty().size() > 0 && pocetSloupecku > 0) {
    1.66 +
    1.67 +                        v.getTabulky().add(t);
    1.68 +                    } else {
    1.69 +                        v.getHlasky().add(new Hlaska("SQL příkaz byl proveden.", Typ.OK));
    1.70 +                    }
    1.71 +
    1.72 +                } catch (SQLException e) {
    1.73 +                    log.log(Level.SEVERE, "SQL chyba při vykonávání uživatelského dotazu.", e);
    1.74 +                    v.getHlasky().add(new Hlaska("Chybné SQL: " + e.getMessage(), Typ.Chyba));
    1.75 +                } catch (Exception e) {
    1.76 +                    log.log(Level.SEVERE, "Chyba při vykonávání uživatelského dotazu.", e);
    1.77 +                    v.getHlasky().add(new Hlaska("Došlo k chybě dotazu.", Typ.Chyba));
    1.78 +                } finally {
    1.79 +                    zavri(db, ps, rs);
    1.80 +                }
    1.81 +            }
    1.82 +
    1.83 +            v.getHlasky().add(new Hlaska(tipy.getTip(), Typ.Tip, false));
    1.84 +
    1.85 +
    1.86 +
    1.87 +
    1.88 +
    1.89 +        } else {
    1.90 +            v.getHlasky().add(new Hlaska("Došlo k chybě historie.", Typ.Chyba));
    1.91 +        }
    1.92 +        return v;
    1.93 +    }
    1.94 +}