eigene Klasse für DB

Status
Nicht offen für weitere Antworten.
L

loogi

Gast
hallo,

ich habe eine Klasse und darin Methoden um eine Verbuindung zu einer DB herzustellen.

Ich wollte dann eine andere Klasse benützten, um auf diese Methoden zuzugriefen. Das öffnen und schliessen geht ja, aber wenn ich in der anderen Klasse eine SQL Anweisung durchführen will, dann geht das nur wenn ich die Klassen Connection und ResultSet aus der anderen Klasse benützte. Anders ausgedrückt ich muss alle daten zum Verbuindungsaufbau in der neuen Klasse nochmal angeben. Das macht ja dann kein Sinn, dann brauch ich die Klasse ja garnicht. Ich möchte aber eine eigene Klasse nur mit Verbindungen, und eine andere um SQL Anweisungen durchzuführen. Muss ich die dann Vererben ? ist das Sinnvoll?
Wie löst man dieses Problem?

danke
 
G

Guest

Gast
Code:
public class ServiceLocator
{
   ...

   private ServiceLocator() {}

   public static Connection getConnection() throws SQLException
   {
      ...
   }
}
und entsprechend an allen Stellen verwenden
Code:
Connection connection = ServiceLocator.getConnection();
 
L

loogi

Gast
Anonymous hat gesagt.:
Code:
public class ServiceLocator
{
   ...

   private ServiceLocator() {}

   public static Connection getConnection() throws SQLException
   {
      ...
   }
}
und entsprechend an allen Stellen verwenden
Code:
Connection connection = ServiceLocator.getConnection();


soll das eine eigene Klasse sein? oder kommt das in die DB Klasse?

und das Resultset?
 

DP

Top Contributor
eigene db-klassen machen sinn, wenn man ähnliche db-aufgaben wiederholt machen will. um ab und an eine db-abfrage zu starten kannste dir den zirkus sparen. connection, statement und resultset wirst du bei queries immer brauchen. es sei denn du benutzt frameworks wie hibernate
 
G

Guest

Gast
ich weiß nicht ob meine Frage richtig verstanden worden ist, deshalb nochmal mit code..

hab hier ne Klasse die ich nur zum Aufbau der DB benützten möchte.
Die Klasse 'Anlegen' mit der möchte ich dann Daten anlegen etc. so funktioniert es aber nicht, da Connection, Resultset, ujnd Statement in der Klasse Anlegen nicht die selben sind wie in DBConnection. Und ich brüchte ja genau diese, weil ich ja die Methoden open und close DBConn von der Klasse DBConnectoe benutzte.

Ich will nicht jedesmal alles neu schreiben...
Also wenn ich den ServiceLocator nehme, wie sieht denn dann der code konkret aus? danke




Code:
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class DBConnector {

	Connection conn;

	Statement st;

	ResultSet rs;

	

	public void openDBConn() {

		try {
			Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
			this.conn = DriverManager.getConnection("jdbc:odbc:logWSTest");
			System.out.println("DB connection erfolgreich");

		} catch (Exception e) {
			System.out.println("Fehler beim DB aufbau");
		}
	}

	public void closeDBConn() {
		try {
			this.conn.close();
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}


Code:
public class Anlegen {

	
	Connection conn;

	Statement st;

	ResultSet rs;
	private String p_name, p_nummer, abteilung;	
	
	
	
public void anlegen_Daten() {

DBConnector db = DBConnector();
db.openopenDBConn():
		
		try {

			st = conn.createStatement();
			st.execute("INSERT INTO lager_berlin(p_name,p_nummer,abteilung)"
					        + " VALUES"
					        + "('"
							+ "','"
							+ this.p_name
							+ "','"
							+ this.p_nummer
							+ "','"
							+ this.abteilung +"');");

		} catch (SQLException e) {
			System.out.println(" Fehler beim anlegen des Datensatzes");

			e.getMessage();
			
		}

db.closeDBConn();
	}
 
G

Guest

Gast
Code:
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Properties;

public class ServiceLocator
{
   public static final String JDBC_DRIVER = "jdbc.driver";
   public static final String JDBC_URL = "jdbc.url";
   public static final String JDBC_USER = "jdbc.user";
   public static final String JDBC_PASSWORD = "jdbc.password";
   
   private static boolean driverLoaded = false;
   
   private ServiceLocator() {}
   
   public static Connection getConnection() throws SQLException, ServiceException
   {
      Properties properties = getConnectionProperties();
      loadDriver(properties);
      Connection connection = DriverManager.getConnection(
         properties.getProperty(JDBC_URL),
         properties.getProperty(JDBC_USER),
         properties.getProperty(JDBC_PASSWORD)
      );
      return connection;
   }
   
   private static void loadDriver(Properties properties) throws ServiceException
   {
      if(!driverLoaded)
      {
         try
         {
            Class.forName(properties.getProperty(JDBC_DRIVER));
            driverLoaded = true;
         }
         catch (ClassNotFoundException e)
         {
            throw new ServiceException(String.format("Driver class '%1$s' not found.", properties.getProperty(JDBC_DRIVER)), e);
         }
      }
   }
   
   private static Properties getConnectionProperties()
   {
      Properties props = new Properties();
      props.put(JDBC_DRIVER, "sun.jdbc.odbc.JdbcOdbcDriver");
      props.put(JDBC_URL, "jdbc:odbc:logWSTest");
      props.put(JDBC_USER, "");
      props.put(JDBC_PASSWORD, "");
      return props;
   }
}

class ServiceException extends Exception
{
   private static final long serialVersionUID = 8034809517719617395L;

   public ServiceException(String message, Throwable cause)
   {
      super(message, cause); 
   }
}

Code:
   public void anlegen_Daten(String p_name, String p_nummer, String abteilung)
   {
      Connection connection = null;
      PreparedStatement stmt = null;
      try
      {
         connection = ServiceLocator.getConnection();
         stmt = conn.prepareStatement("INSERT INTO lager_berlin(p_name,p_nummer,abteilung) VALUES(?,?,?)");
         stmt.setString(1, p_name);
         stmt.setString(2, p_nummer);
         stmt.setString(3, abteilung);
         stmt.executeUpdate();
      }
      catch (SQLException e)
      {
         ...
      }
      catch (ServiceException e)
      {
         ...
      }
      finally
      {
         if(stmt != null)
         {
            try
            {
               stmt.close();
            }
            catch(SQLException e)
            {
               ...
            }
         }
         if(connection != null)
         {
            try
            {
               connection.close();
            }
            catch(SQLException e)
            {
               ...
            }
         }
      }
   }
oder vergiss das ganze und verwende Hibernate oder von mir aus mindestens Apache DBUtils
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
D Klassen Eigene Klasse für ArrayList Java Basics - Anfänger-Themen 6
J Eigene Klasse für die Variablen? Java Basics - Anfänger-Themen 3
F Eigene Klasse für die Keys von HashMap Java Basics - Anfänger-Themen 5
T Konstruktor für eigene Klasse erstellen Java Basics - Anfänger-Themen 6
G Eigene Klasse für externe Befehle - Warten auf Prozesse Java Basics - Anfänger-Themen 6
F Eigene Klasse für Events Java Basics - Anfänger-Themen 10
Amina556 Eigene Klasse definieren Java Basics - Anfänger-Themen 9
L Meine erste eigene Exception Klasse Java Basics - Anfänger-Themen 10
D Attribut Telefonnummer - eigene Klasse oder String Java Basics - Anfänger-Themen 13
S Eigene LinkedList Klasse Java Basics - Anfänger-Themen 4
H Klassen auf eigene Klasse zugreifen Java Basics - Anfänger-Themen 2
B Klassen Eigene "non static" Klasse in Main verwenden! Java Basics - Anfänger-Themen 12
S Wann existiert eine Instanz (eigene Klasse) Java Basics - Anfänger-Themen 8
S Eigene Exception Klasse - fehlender Konstruktor mit String Java Basics - Anfänger-Themen 3
B eigene klasse in listen eintragen Java Basics - Anfänger-Themen 6
A Objekte in eigene Klasse auslagern Java Basics - Anfänger-Themen 2
Kenan89 ActionListener in eigene Klasse Java Basics - Anfänger-Themen 8
E Object in eigene Klasse umwandeln? Java Basics - Anfänger-Themen 7
F Klassen Eigene Klasse definieren Java Basics - Anfänger-Themen 4
T eigene Exception Klasse Java Basics - Anfänger-Themen 12
G Eigene Klasse als Array, zugriff? Java Basics - Anfänger-Themen 2
S Eigene Stack Klasse Java Basics - Anfänger-Themen 26
W GUI als eigene Klasse oder in die Startklasse? Java Basics - Anfänger-Themen 21
H Buttonbefehle in eigene Klasse schreiben Java Basics - Anfänger-Themen 8
nrg Eigene simple List-Klasse programmieren Java Basics - Anfänger-Themen 3
M eigene Property-Klasse Java Basics - Anfänger-Themen 2
L Aus einer Methode eine eigene Klasse machen - modular coden Java Basics - Anfänger-Themen 14
E Eigene Stack Klasse schreiben Java Basics - Anfänger-Themen 12
M Eigene Klasse mit "Enumeration"-Datentyp verknüpfe Java Basics - Anfänger-Themen 16
B eigene Klasse wird nicht im Hauptprogramm erkannt! Java Basics - Anfänger-Themen 4
U Eigene klasse schreiben Java Basics - Anfänger-Themen 13
A meine eigene IO Klasse Java Basics - Anfänger-Themen 3
G Vererbung: Methoden die eigene Klasse zurückgeben Java Basics - Anfänger-Themen 8
B Panel mit Radiobuttons als eigene Klasse Java Basics - Anfänger-Themen 4
E Eigene Klasse erstellen? Java Basics - Anfänger-Themen 21
D Eigene Klasse als Import Java Basics - Anfänger-Themen 10
M eigene klasse definieren und verfügbar machen Java Basics - Anfänger-Themen 9
T Eigene Exception - ohne werfen abfangen Java Basics - Anfänger-Themen 2
T Datentypen Eigene Datentypen Java Basics - Anfänger-Themen 15
low_in_the_head Eigene Exception nutzen Java Basics - Anfänger-Themen 4
C Archiv für eigene Klassen Java Basics - Anfänger-Themen 9
B JUnit 4: Wie man die eigene Liste testen kann [TDD] Java Basics - Anfänger-Themen 46
C eigene Methoden erstellen (Instanzmethoden) Java Basics - Anfänger-Themen 7
I Eigene Java Tools Nutzung Java Basics - Anfänger-Themen 6
G eigene Bibliothek einbinden Java Basics - Anfänger-Themen 1
K Eigene Annotations, Pre-/Post-/Call-Method Java Basics - Anfänger-Themen 6
O Erste Schritte Eigene charAt(i) Methode schreiben Java Basics - Anfänger-Themen 10
D Methoden Eigene Methode um alle Ausgaben aufzurufen Java Basics - Anfänger-Themen 17
L Eigene Exception schreiben bei zu langem Array Java Basics - Anfänger-Themen 10
P Maven und eigene Jars Java Basics - Anfänger-Themen 4
J Algorithmus - Strings auf eigene Reihenfolge miteinander vergleichen Java Basics - Anfänger-Themen 4
R Interface Eigene Objekte in Listen sortieren mit Interface Comparable Java Basics - Anfänger-Themen 5
A Eigene Methoden entwicken Java Basics - Anfänger-Themen 3
F Klassen Eigene Exception Bedingungen festlegen Java Basics - Anfänger-Themen 2
H GSON-Bibliothek für eigene Programme benutzen Java Basics - Anfänger-Themen 2
N Eclipse - eigene Icons unter ClassPath Resource Java Basics - Anfänger-Themen 0
N Eigene Stream Methoden implementieren Java Basics - Anfänger-Themen 3
R eigene Graphikbedienelemente Java Basics - Anfänger-Themen 8
V Generics / eigene Liste Java Basics - Anfänger-Themen 4
T Eigene Bedingung in IF-Bedingung Java Basics - Anfänger-Themen 22
P Java 8 & Eigene Applets Java Basics - Anfänger-Themen 3
E Best Practice Exaktes Rechnen mit (Pseudo-)Rationalen/Realen Zahlen. Operations Zuweisung für (eigene) Klassen Java Basics - Anfänger-Themen 3
G eigene Bibliothek in Java importieren Java Basics - Anfänger-Themen 5
M Wann eigene implementierte HashCode Methode zwingend erforderlich? Java Basics - Anfänger-Themen 1
P Vererbung Eigene HashMap Variante Java Basics - Anfänger-Themen 2
P Eigene Knöpfe mit eigenem Listener Java Basics - Anfänger-Themen 5
T Muss ein Parametertest immer eine eigene Testklasse sein? Java Basics - Anfänger-Themen 3
B Multithreading und eigene Queue entwickeln Java Basics - Anfänger-Themen 3
O GUI: Eigene Fenster "Form"? Java Basics - Anfänger-Themen 13
F Eigene LinkedList - toString Java Basics - Anfänger-Themen 10
O Denkanstöße für eigene Konfigurations-Datei Java Basics - Anfänger-Themen 12
SexyPenny90 Wieso ist diese eigene Equals-Methode schlecht? Java Basics - Anfänger-Themen 17
C eigene Exception Java Basics - Anfänger-Themen 4
M externe JARs in die eigene JAR einbinden Java Basics - Anfänger-Themen 9
V Klassen import - einfaches Umleiten auf eigene Klassen? Java Basics - Anfänger-Themen 8
S [JavaFX 2.1] - Eigene Sprachauswahl? Java Basics - Anfänger-Themen 4
K Klassen Eigene Exception verwenden Java Basics - Anfänger-Themen 9
J eigene packages bzw klassen verwenden Java Basics - Anfänger-Themen 25
E Eigene Stackklasse Java Basics - Anfänger-Themen 7
B Eigene Exceptions entwerfen Java Basics - Anfänger-Themen 3
S Eigene Exception Schreiben und Welche Auslösen wie ? Java Basics - Anfänger-Themen 7
P eigene kleine Datenverwaltung Java Basics - Anfänger-Themen 5
N Eigene Methoden-> Werte übergeben Java Basics - Anfänger-Themen 5
U Klassen Eigene Klassen importieren Java Basics - Anfänger-Themen 13
S Eigene Klassen addieren Java Basics - Anfänger-Themen 3
B OOP Eigene Objekte in Arrays zusammenfassen Java Basics - Anfänger-Themen 3
E Eigene class datum Java Basics - Anfänger-Themen 2
G Eigene MessageBox kreieren Java Basics - Anfänger-Themen 9
I Erste Schritte Eigene Fehlermeldungen bei Exceptions Java Basics - Anfänger-Themen 19
S Eigene KeyEvent-Mask erstellen Java Basics - Anfänger-Themen 4
X Eigene Libary Java Basics - Anfänger-Themen 2
Crashbreaker Eigene Java-Programm ohne hilfe des CMD starten Java Basics - Anfänger-Themen 11
A Klassen Eigene Datenklasse - Strings mit fixer Länge Java Basics - Anfänger-Themen 2
G Shape um eigene Achse drehen Java Basics - Anfänger-Themen 2
P Vererbung Basisklasse soll eigene Methode benutzen Java Basics - Anfänger-Themen 38
J Eigene kleine Datenbank programmieren Java Basics - Anfänger-Themen 2
xehpuk Ordner "Eigene Bilder" ansteuern Java Basics - Anfänger-Themen 3
V Sonderzeichen als eigene "Operatoren" im JTextField Java Basics - Anfänger-Themen 4
D Eigene equals methode schreiben Java Basics - Anfänger-Themen 4
dataframe OOP Eigene typisierte Liste Java Basics - Anfänger-Themen 3

Ähnliche Java Themen

Neue Themen


Oben