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 +}