Klassen Template-Klasse für Datenbank-Abfragen erstellen

purzel

Bekanntes Mitglied
Hallo,

ich habe vor mein derzeitiges Webprojekt etwas zu vereinfachen. Dafür habe ich mir überlegt, mach ich doch für alle Anfragen an die Datenbank eine Klasse die ich dann nur noch mit Parameter füllen muss.

Leider scheitere ich an einem Punkt:

so sieht derzeit meine Klasse aus
Java:
package de.pcpowerplay.database;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;

/**
 *
 * @author purzel
 */
public class query {
    /**
     * Datenbank
     */
    final String db_driver = "com.mysql.jdbc.Driver";
    final String db_url = "jdbc:mysql://xxx.xxx.xxx.xxx/pcpowerplay";
    final String db_username = "yyyyy";
    final String db_password = "zzzzz";

    ResultSet rs;

    public query(String query, String... prepStmt) {
        try{
            Class.forName(db_driver);
            try{
                Connection db = DriverManager.getConnection(db_url, db_username, db_password);
                    String selectStatement = query; // SELECT, Abfrage aus DB {1}
                    PreparedStatement select_prepStmt = db.prepareStatement(selectStatement);
                    for(int i = 0; i < prepStmt.length; i++) {
                        select_prepStmt.setString(i+1, prepStmt[i]); // Parameter die in 1 mit ? gekennzeichnet sind füllen {2}
                    }
                    rs = select_prepStmt.executeQuery();
                    while(rs.next()) {
                        //beliebige Arrays füllen, unbekannt!! {3}
                    }
                rs.close();
                db.close();
            } catch (Exception db_error) {
                System.out.println(db_error);
            }
        } catch(Exception db_driver_error) {
            System.out.println(db_driver_error);
        }
    }
}

bei Nummer 3 hänge ich fest!

Zur Erläuterung:

  1. Select Abfrage aus Datenbank
  2. ? - Zeichen mit Werten belegen
  3. Array füllen und später wieder an aufrufende Klasse übergeben

So wie mache ich das nun wenn ich folgendes ohne Klasse mache?

Java:
suche_spalten[] suche = new suche_spalten[15];
try{
                Class.forName(db_driver);
                try{
                    Connection db = DriverManager.getConnection(db_url, db_username, db_password);
                    if(search_item.equals("1")) {
                        String selectStatement = "SELECT id, titel, inhalt FROM news WHERE inhalt LIKE ?";
                        PreparedStatement select_prepStmt = db.prepareStatement(selectStatement);
                        select_prepStmt.setString(1, "%" + search_value + "%");
                        rs = select_prepStmt.executeQuery();
                        while(rs.next()) {
                            suche[i] = new suche_spalten(rs.getInt("id"), rs.getString("titel"), rs.getString("inhalt"));
                            i++;
                        }
                    } else if(search_item.equals("2")) {
                        String selectStatement = "SELECT id, username FROM users WHERE username LIKE ?";
                        PreparedStatement select_prepStmt = db.prepareStatement(selectStatement);
                        select_prepStmt.setString(1, "%" + search_value + "%");
                        rs = select_prepStmt.executeQuery();
                        while(rs.next()) {
                            suche[i] = new suche_spalten(rs.getInt("id"), rs.getString("username"));
                            i++;
                        }
                    }
                    rs.close();
                    db.close();
                } catch (Exception db_error) {
                    System.out.println(db_error);
                }
            } catch(Exception db_driver_error) {
                System.out.println(db_driver_error);
            }
            return suche;

Bitte um Hilfe :)

Danke schon mal fürs lesen ;)
 
G

Gast2

Gast
Aus dem ResultSet kannst du dir Metadaten holen, z.b. die Anzahl der Spalten oder deren Namen. Darauf kannst du dann dein Array aufbauen. Wobei man überlegen könnte ob da nicht ne andere Datenstruktur schöner wäre.
 

purzel

Bekanntes Mitglied
Ah MetaDaten, hört sich gut an, zumindest was ich darüber bis jetzt gefunden habe! Danke, bei Problemen melde ich mich wieder! :)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
G Template Methoden/Klasse Allgemeine Java-Themen 7
L Template Engine entwerfen und implementieren Allgemeine Java-Themen 4
M Aus XML ein Word-Dokument(Template) füllen Allgemeine Java-Themen 8
X Template Matching (subimage recognition via Formel) vs KNN Allgemeine Java-Themen 36
Thallius PDF oder Word als Template benutzen Allgemeine Java-Themen 1
I itext Libreoffice Java und ein PDF Template Allgemeine Java-Themen 1
J Eclipse JavaDoc Template Allgemeine Java-Themen 16
hdi Eclipse laggt bei Template Proposals Allgemeine Java-Themen 3
I Template Method pattern mit "geschützten Methoden" Allgemeine Java-Themen 5
C Velocity liest template-Dateien nicht aus einem Verzeichnis Allgemeine Java-Themen 3
André B. Was sollte eine Template Engine können? Allgemeine Java-Themen 3
S Datei nach Template interpretieren Allgemeine Java-Themen 5
M Methodenübersicht einer Klasse einsehen Allgemeine Java-Themen 14
Jose05 Java-Klasse im extra cmd-Fenster ausführen Allgemeine Java-Themen 3
torresbig Klasse mit extends Calendar über Methoden ändern (Hirnblockade) Allgemeine Java-Themen 7
A Zweite Service Klasse beim Kompilieren Allgemeine Java-Themen 6
B Ein Objekt einer Klasse mehreren anderen Klassen zur Verfügung stellen? Allgemeine Java-Themen 6
Atten007 Java-Klasse auf macOS entpacken? Allgemeine Java-Themen 2
M Klasse durch Klassen Aufteilung verbessern, aber wo? Allgemeine Java-Themen 1
E Eine Methode einer extendeten Klasse deakitivieren Allgemeine Java-Themen 12
H Kombination Interface und Abstrakte Klasse bei Generics Allgemeine Java-Themen 3
EinNickname9 Best Practice Singleton und Singleton mit Instanz zu anderer Klasse -Pattern Allgemeine Java-Themen 30
Y ImagePanel von anderer Klasse in eine MainFrame Klasse hinzufügen. Allgemeine Java-Themen 1
Lukas2904 Schleife mit ansteuerung einer Klasse Allgemeine Java-Themen 5
d.lumpi Aus Einer Klasse auf ein Objekt einer anderen Klasse Zugreifen Allgemeine Java-Themen 1
missy72 Klassen Eigene Klasse MessageWindow ähnlich der Alert Klasse Allgemeine Java-Themen 2
Drachenbauer wie kann ich alle instanzen einer Klasse durchsehen, ohne, dass diese in einer Liste erzeugt wurden? Allgemeine Java-Themen 11
kanywayne Java programmieren: Polynom Klasse Allgemeine Java-Themen 4
L Die abzuleitende Klasse als Parameter übergeben Allgemeine Java-Themen 4
S Klassen Einfügen von unbekannter menge an Variablen in eine Klasse mithilfe von ASM Allgemeine Java-Themen 5
C Klasse mit Mockito simulieren Allgemeine Java-Themen 9
P einen public <Optinal String> in einer anderen Klasse mit einem Int vergleichen Allgemeine Java-Themen 2
S Wenn eine Klasse zwei Interfaces mit derselben Methodensignatur implementiert: welche wird aufgerufen? Allgemeine Java-Themen 15
Thallius Key/Value Table in Klasse einlesen Allgemeine Java-Themen 14
S static in Interface und Klasse Allgemeine Java-Themen 2
W Was genau sind IOTools? Kann ich stattdessen nicht die Scanner Klasse verwenden? Allgemeine Java-Themen 3
V Threads Probleme beim Aufrufen von Methoden einer anderen Klasse (Threads) Allgemeine Java-Themen 14
X Collections Gibt es eine Klasse welche die Vorteile von List und HashMap vereint, aber konstante Laufzeit (O(1)) hat in Java? Allgemeine Java-Themen 4
D javassist API Klasse in MethodCall ermitteln Allgemeine Java-Themen 8
kodela Klasse mit "gezipten" Daten Allgemeine Java-Themen 6
J Builder Klasse mit Lombok bauen Allgemeine Java-Themen 2
L Operatoren Java Reflections: Alle Methoden einer Klasse aufrufen ohne Exceptions Allgemeine Java-Themen 5
M [SOAP] - Klasse aus WSDL ausschließen Allgemeine Java-Themen 2
N Generic Type einer Generischen Klasse während der Laufzeit bekommen Allgemeine Java-Themen 2
X Klassen Klasse BreakIterator Allgemeine Java-Themen 6
R Arraylist in andere Klasse leiten und bearbeiten Allgemeine Java-Themen 10
kodela Klassen Klasse "vergisst" ihre Daten Allgemeine Java-Themen 2
pkm Kann eine ServerSocket-Klasse nicht stateful sein? Allgemeine Java-Themen 4
E Socket Dynamische Klasse von ObjectOutputStream lesen. Allgemeine Java-Themen 8
M Matcher-Klasse findet match nicht Allgemeine Java-Themen 6
cool_brivk24 Variablen abfragen von Boolean von anderer Klasse Allgemeine Java-Themen 12
S Seltsames Ergebnis mit Date-Klasse Allgemeine Java-Themen 6
J int Werte in einer anderen Klasse in Arrays speichern Allgemeine Java-Themen 3
D Warum kann ich eine (deflaut) Klasse aus einer Libary in einem anderen Projekt benutzen? Allgemeine Java-Themen 3
Neoline Klassen Singleton Klasse buchmanager Allgemeine Java-Themen 19
M Kapselung Modellierung von Intervallen: Klasse Interval Allgemeine Java-Themen 4
B Übernommene Variablen(werte) aus der Main-Klasse ändern? Allgemeine Java-Themen 9
ReinerCoder Klasse kann nicht public deklariert werden Allgemeine Java-Themen 2
ReinerCoder Methode einer Klasse meldet Fehler "misplaced construct(s)" Allgemeine Java-Themen 13
I Collection - contains-Methode überschreiben (anonyme innere Klasse) Allgemeine Java-Themen 4
X Klassen File-Klasse wird als Directory markiert Allgemeine Java-Themen 8
S Methoden Liste soll Methode aus innerer Klasse aufrufen Allgemeine Java-Themen 4
J IndexOutOfBoundsException bei der Nutzung der Klasse Message von mime4j Allgemeine Java-Themen 5
P Array einer abstrakten Klasse Allgemeine Java-Themen 4
J Zugriff auf erstellte Objekte einer Klasse von einer Klasse ausserhalb Allgemeine Java-Themen 3
kodela Dynamisches Array in einer Klasse Allgemeine Java-Themen 5
M Was geschieht mit Java-Klasse, die aus ArrayList entfernt wird? Allgemeine Java-Themen 10
perlenfischer1984 Lombok Builder soll andere Klasse bauen Allgemeine Java-Themen 4
perlenfischer1984 Mit Lombok Builder Felder in Super Klasse füllen Allgemeine Java-Themen 12
T String aus While Schleife für ganze Klasse sichtbar machen Allgemeine Java-Themen 5
K Best Practice Auf die Klasse zugreifen im erzeugten ActionListener Allgemeine Java-Themen 2
K Mit Button neue Klasse öffnen Allgemeine Java-Themen 9
J Reflection mit Klasse und Subklasse Allgemeine Java-Themen 11
C Classpath Neue Klasse über einen Button ausführen Allgemeine Java-Themen 3
magdaStone Logikproblem Umschalten von booleans in anderer Klasse Allgemeine Java-Themen 7
P mehrer Verschiedene Objekte in einer Klasse erstellen. Allgemeine Java-Themen 4
A Java Klasse auf Tomcat während der Laufzeit austauschen Allgemeine Java-Themen 1
C Abstrakte Klasse, lokale Variable-Problem Allgemeine Java-Themen 1
N Vererbung Design-Problem mit vorhandenen, von der Klasse unabhängigen Methoden Allgemeine Java-Themen 12
Messoras Klassen Sämtliche Variablen einer Klasse übernehmen Allgemeine Java-Themen 6
H Methoden Methode 'updateItem' der Klasse 'TreeCell' Allgemeine Java-Themen 3
B Animierte Klasse schreiben - Wie? Allgemeine Java-Themen 9
M Klassen Eine Klasse in mehreren Klassen einbinden Allgemeine Java-Themen 11
N Methoden Methoden einer Klasse auf Grundlage eines Strings aufrufen Allgemeine Java-Themen 6
AssELAss Log4j Logging Ausgabe für jede Klasse in seperates File Allgemeine Java-Themen 2
L Eclipse JavaFX Klasse starten programmatisch Allgemeine Java-Themen 1
F Try/catch über ganze Klasse Allgemeine Java-Themen 9
L Von ArrayList abgeleitete Klasse nur mit bestimmten Objekten füllen Allgemeine Java-Themen 1
so_ein_Komischer Erste Schritte java Math Klasse finden? Allgemeine Java-Themen 2
J beans.instantiate(): Klasse kann nicht instanziiert werden Allgemeine Java-Themen 2
I Interface Interface / Klasse - wieso Abstract? Allgemeine Java-Themen 13
R Abstrakte Basisklasse und instanzierte Objekte der abgeleiteten Klasse als Basisklasse übergeben Allgemeine Java-Themen 2
F Methodenaufruf mit abgeleiteter Klasse als Arg... Allgemeine Java-Themen 10
M Klasse in separaten Thread ausführen.Wie genau? Allgemeine Java-Themen 2
A Best Practice Unterschied zwischen einer sauberen Dependency Injection und einer statischen Klasse Allgemeine Java-Themen 5
F Methoden in der Enumeration Klasse Allgemeine Java-Themen 1
S Die Initialisierung von Feldern in ableitender Klasse erzwingen..? Allgemeine Java-Themen 16
S Mit Generics Klasse erstellen die selbst T erweitert..? Allgemeine Java-Themen 4
M Variable außerhalb Klasse definierbar? Allgemeine Java-Themen 2
F Abstrakte Klasse in "For each" Schleife Allgemeine Java-Themen 1

Ähnliche Java Themen

Neue Themen


Oben