Frage bezüglich Codedesigns

Status
Nicht offen für weitere Antworten.

WeirdAl

Bekanntes Mitglied
Hi,
ich habe innerhalb meines Projekts ein paar statische Klassen die Methoden anbieten, die verschiedenste SQL Selects, Updates, Deletes auf einer mySQL DB ausführen. Die einzelnen Methoden haben verschiedene Paramater und Rückgabewerte, aber der Kern der Methoden ist gleich:

Code:
Methode die eine SQLException wirft
...
PreparedStatement  pst = null;
ResultSet  rs = null;
Connection cn = null;
	    	    
	    try {
	    	 // load driver and connect
	    	 Class.forName( driver );
	         cn = DriverManager.getConnection( dbUrl, dbLogin, dbPW );
	         

	         pst = cn.prepareStatement("...");
	         pst.setInt(1, ...);

                 ...               

	         rs = pst.executeQuery();
         
	         rs.next(); 
	         ....
	         } catch (ClassNotFoundException e) {
				System.err.println(e);
			} 
				
			finally {
				pst.close();
		        rs.close();
		        cn.close(); 
			}

Der Teil ist praktisch in allen Methoden gleich. Einzig die speziellen PreparedStatements und deren "Verarbeitung" unterscheiden sich innerhalb dieses Codeblocks. Kann ich die "gleichen" Teile irgendwie auslagern? Ich habe keine Idee wie ich dies machen könnte, aber mich stört es, dass ich innerhalb einer Klasse 10x diesen Try/Catch/Final habe.

Vielleicht weiß jemand von euch Rat, Danke :)

Cu
Alex
 
A

Azubi

Gast
Schreib dir doch ne SQL Klasse.
Sollte man ausserdem nicht eh beim starten des Programmes EINE Connection erstellen und nicht immer wieder eine öffnen, closen, öffnen, closen?

Dann kannste nämlich mit deiner Klasse eine Connection erstellen, die über die Laufzeit des Programms erhalten bleibt.
Die Klasse kann ja dann noch Methoden haben wie:
executeStatement(); (für update, delete, ...)
getQueryStatement(); (für Select z.b. Was dann eben ein ResultSet zurückgibt)
Den 2 Methoden kannst du dann z.B. entweder nen String mit dem Statement was ausgeführt werden soll übergeben, oder aber direkt ein Statement. Bleibt ja dir überlassen wie dus handhaben willst.

Hilft dir das? :D
 

WeirdAl

Bekanntes Mitglied
Das mit der SQL Klasse muss ich mir mal ansehen (also generelles Vorgehen usw., ich hab mir da bislang noch gar nix angesehen). Mit der Connection weiss ich nicht was besser ist. Da das Projekt eine JSF Webapplikation ist, müsste ich dann pro Nutzer eine Connection zur Verfügung stellen, da ansonsten 100 Nutzer über eine Connection "geschliffen" werden.

Jedenfalls danke für die Denkanstöße :). Wie Du durch meinen obigen Text sicher mitbekommen hast, muss ich erstmal googlen und mir klar werden, wie ich nun weitermachen werde :)

Cu
Alex
 

Yzebär

Bekanntes Mitglied
Du könntest eine statische Methode schreiben, der ein PrepareStatement übergeben wird und die ein ResultSet zurückgibt (wenn es eines gibt, ansonsten ohne Rückgabewert).

Ich verwende generell immer eine eigene Klasse, die alle Zugriffe auf die DB kapselt und die Dinge die sich stets ändern (Statements) als Parameter bekommen und die Ergebnisse die dann verarbeitet werden sollen (Resultset) als Returnwert haben.

Das mit der Connection würde ich auch ändern, ist doch egal, ob alle User über eine einzige Connection von der DB bedient werden. Wenn es sehr, sehr viele Zugriffe gibt, könnte man überlegen einen Connectionpool zu verwenden. Wäre auf jeden Fall effizienter, als jedesmal eine Connection zu öffnen und danach wieder zu schließen.
 
G

Guest

Gast
Nimm in Webanwendungen auf jeden Fall immer ConnectionPools.

Außerdem darfst du dich nicht wundern, daß du in einer Architektur, die auf statischen Methoden beruht, wiederholende Codestellen findest. Dazu gibt es die OOP; schreibe eine Basisklasse, die generische select, insert/update und delete-Statements ausführen kann und leite Basisklassen ab, die diese generischen Methoden benutzen.

Dringend abraten würde ich auch von der Rückgabe eines ResultSets, am besten noch in die View. Dazu benutzt man Transfer-Objekte, die ResultSets sollten dann schon längst geschlossen sein.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
J NetBeans Frage bezüglich der Scanner-Klasse Allgemeine Java-Themen 6
KonradN Mal eine Frage zu Binary Serialization Allgemeine Java-Themen 15
8u3631984 Frage zu Java Streams min / max Allgemeine Java-Themen 17
8u3631984 Frage Performance bei Linked List und Array List Allgemeine Java-Themen 5
H Frage regex greater than less than Allgemeine Java-Themen 7
berserkerdq2 Frage zu IntelliJ und JavaFX Allgemeine Java-Themen 1
W Timer Konzept-Frage Allgemeine Java-Themen 16
T Eine Frage des Designs Allgemeine Java-Themen 2
C Frage zu eigenem TableCellRenderer Allgemeine Java-Themen 11
C Programmvorstellung & Frage zum Thema Geschäftsform Allgemeine Java-Themen 51
J Frage zu System.getproperties. Allgemeine Java-Themen 60
molat100 wie kann man die Frage beantworten Allgemeine Java-Themen 1
pkm Frage zur Präzision von Calendar.WEEK_OF_YEAR Allgemeine Java-Themen 12
J Eine Frage zu den Threads und Task Allgemeine Java-Themen 1
pkm Frage nach eventuellem syntaktischen Zucker bei der Konkatenation von ArrayLists Allgemeine Java-Themen 4
M Frage-Antwortspiel wie Wer wird Millionär Allgemeine Java-Themen 1
F Frage zu System.in Allgemeine Java-Themen 3
marcooooo Frage zum Beispiel im Anhang Allgemeine Java-Themen 16
T Meine Frage lautet wie ich 2 CSV Dateien miteinander in Java verbinde und Spalten die zueinander gehören durch den gleichen Key zusammen ausgebe? Allgemeine Java-Themen 5
S Noch eine Design-Frage zu Setter Allgemeine Java-Themen 6
B For-Loop Frage Allgemeine Java-Themen 21
L Java frage Allgemeine Java-Themen 3
bueseb84 Frage zu Mock und UpperBound Allgemeine Java-Themen 2
M Frage zum Konstruktor Allgemeine Java-Themen 2
W Best Practice Frage zur Umsetzung MVC Allgemeine Java-Themen 9
P String-Verschlüsselung - Frage zur Sicherheit Allgemeine Java-Themen 21
B Frage zu Unit-Tests Allgemeine Java-Themen 6
T Allgemeine Frage: GUI für 3D-Visualisierung Allgemeine Java-Themen 5
R Allgemeine Frage zu RMI bei MVC Allgemeine Java-Themen 2
O Frage zum Runtimeverhalten von Java ... Allgemeine Java-Themen 2
H Rundreise frage (Algorithmus) Allgemeine Java-Themen 18
B Generelle Frage bei einer Webanwendung / Reduzierung von DB Abfragen Allgemeine Java-Themen 1
D Frage zu Vererbung Allgemeine Java-Themen 5
J Frage zu regulärem Ausdruck Allgemeine Java-Themen 2
M Allgemeine Frage: Wie lernt man Java / Programmieren von Grund auf? Allgemeine Java-Themen 7
rentasad Design-Frage - Interfaces, Klassen, statische Methoden Allgemeine Java-Themen 3
S Frage zur JLS Allgemeine Java-Themen 0
J Verständnis Frage zur Instanz, Objekte, Instanzierung, Referenz Allgemeine Java-Themen 14
A Methoden Allgemeine Java Frage Allgemeine Java-Themen 3
E String Frage Allgemeine Java-Themen 9
I bin neu bei GitHub, Frage zur Sicherheit Allgemeine Java-Themen 14
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
C KeyListener Frage Allgemeine Java-Themen 3
T Frage zu UML in Java programmieren Allgemeine Java-Themen 1
R Konstanten initialisieren - FRAGE Allgemeine Java-Themen 3
MTJ004 FTP Frage zu FTP Speicherung Java-Android-FTP Allgemeine Java-Themen 5
J Frage zum Entwurf / json-Datenmodell Allgemeine Java-Themen 8
A Frage zu meinem Code Allgemeine Java-Themen 2
RalleYTN Classpath Nur ne kleine Frage zur MANIFEST.MF Allgemeine Java-Themen 4
T Frage zu Access Modifiers Allgemeine Java-Themen 6
W Input/Output Frage zu pdfbox und FileUtils Allgemeine Java-Themen 2
O Frage zur Implementierungsweise Allgemeine Java-Themen 4
B Frage zu Bitshift Allgemeine Java-Themen 3
J Java Zufallsgenerator (6 aus 49) Frage Allgemeine Java-Themen 7
L Frage zu RIA und GWT Allgemeine Java-Themen 0
P Concurrency Frage Allgemeine Java-Themen 8
M Frage zu Enumerations Allgemeine Java-Themen 2
F Unlimited Strength Policy. Frage Verbreitung der Anwendung Allgemeine Java-Themen 1
F Frage zur Library JTS Allgemeine Java-Themen 5
S Java Design Frage Allgemeine Java-Themen 10
E Reflection? Frage Allgemeine Java-Themen 4
C FileInputStream frage Allgemeine Java-Themen 6
G Polymorphie Programmdesign Frage Allgemeine Java-Themen 20
Uzi21 Frage zu NetBeans ( Console) Allgemeine Java-Themen 11
D Classpath Frage zum Java Resource Loading Allgemeine Java-Themen 2
G Frage zu JPA Allgemeine Java-Themen 1
S Methoden Frage Allgemeine Java-Themen 2
P MVC - Frage zu Model Allgemeine Java-Themen 4
K Frage zu Locks Allgemeine Java-Themen 1
S Frage zu abstract Allgemeine Java-Themen 5
M ArrayList<String> Frage Allgemeine Java-Themen 7
M OOP Design Frage Allgemeine Java-Themen 2
N Frage zur while-Schleife Allgemeine Java-Themen 18
T Best Practice Auslesen von Zeichenketten (Frage, Antworten, usw) Allgemeine Java-Themen 4
C Eine Frage zur Bearbeitungszeit Allgemeine Java-Themen 8
H Frage wegen Heap-Speicher Allgemeine Java-Themen 2
T Garbage Collection Frage Allgemeine Java-Themen 15
P Kurze Frage: aus einer File die Zeilenanzahl auslesen Allgemeine Java-Themen 9
D Frage zu Java und Umlauten / charsets Allgemeine Java-Themen 2
B Frage zu Java und OpenGL? Allgemeine Java-Themen 3
Q Kapselung Allgemeine Design- Frage Allgemeine Java-Themen 8
A eine test thread.join() frage Allgemeine Java-Themen 2
DStrohma LayoutManager Frage zum GridBagLayout Allgemeine Java-Themen 4
F Frage zu Regex möglich Allgemeine Java-Themen 4
H XML-File mit Java erzeugt Frage Allgemeine Java-Themen 10
D Frage und Antwort Programm, Problem bei Methodenaufruf Allgemeine Java-Themen 3
H Java Vector Frage Allgemeine Java-Themen 9
W Frage... Allgemeine Java-Themen 29
R Frage zur topologischen Sortierung Allgemeine Java-Themen 2
H Frage zu weka.core.Instance Allgemeine Java-Themen 3
Y Kleine Frage zu String.split Allgemeine Java-Themen 3
T Frage zu Klassendesing Allgemeine Java-Themen 3
W Frage zu Refactoring statischer Methoden Allgemeine Java-Themen 4
C Eclipse Wichtige frage Allgemeine Java-Themen 5
H Frage zu java.weka.core.Instances Allgemeine Java-Themen 3
S Frage zu Format Modifiers in Log4j Allgemeine Java-Themen 11
H Frage zu clone() Allgemeine Java-Themen 5
4 Simple(?) Frage zu Threads Allgemeine Java-Themen 14
H2SO3- SCJP Chapter 3 Frage 10. Falsche Antwort? Allgemeine Java-Themen 15
H Frage sinnvolle Datenspeicherung und -verarbeitung Allgemeine Java-Themen 3

Ähnliche Java Themen

Neue Themen


Oben