carookee - group communication for you
Home / JavaForum / JDBC
Infos   |   Features   |   Gold-Edition   |   Kundenservice   
java
  Übersicht
  Forum
Beginner
Java allgemein
JDBC
JNI
Networking
Online-Ressourcen
Swing + AWT
XML
Meckerecke
  Mitglieder
LOGIN





· Passwort vergessen
· Kostenlos anmelden
  Information
  Demo
  Features
  Im Vergleich
  Anmeldung
SUCHE
Beiträge, Foren oder Verfasser finden:
  Kundenservice
  Impressum
  Datenschutz
  AGB
Status
5.772 User online
1 User eingeloggt
 

Beiträge
   Antworten     Neuer Beitrag    

Beitrag 6 von 277 (2%) |<   <   >   >|

Autor SireHages
Datum 19.09.06, 16:29
Betreff kontinuierlicher Speicheranstieg bei langer Datenbank abfrage


Hallo, ich mache gerade in einer Firma Praktikum und soll zur Zeit ein Javaprogramm entwickeln, was von mehreren Datenbanken, verschiedene Tabellen und Datensätze einliest und diese in einer neuer Datenbank als Datensicherung speichert. Funktioniert alles soweit auch wunderbar wenn da nicht ein großes Problem wäre: der Speicherverbrach wächst kontinuierlich(und das Programm ist für den Dauerbetrieb konzipert und hat eine Abfrage/Aktualierungsrate von 5 sek). Habe hierfür eine extra Klasse implementiert:
Kann mir da jemand helfen, bin am verzweifeln!!
(GC arbeitet auch tadlelos, habe das mit jstat geprüft)

package datenbank;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.sql.SQLWarning;
import java.sql.Statement;




/**
* Steht für die Implementierung der Selectabfrage
* !!!Einschränkung: es können maximal immer 10000 Datensätzegelesen werden!!!
*
*/
public class DatenbankS implements DatenbankT {

/**speichert den Datensatz, der durch die Abfrage entstanden ist*/
private static String[][] datensatz;

/**beinhaltet, ob der die Abfrage fehlerfrei durch geführt wurde*/
private static boolean status;

/**die anzahl der Zeilen*/
private static int zeilen;

/**die Anzahl der Spalten*/
private static int spalten;

/**die ausgegebene Fehlermeldung*/
private static String error;

/**Abfrage speichern*/
private String query,url,user,pw,treiber;

/**Speichernung, ob offene Verbindung vorhanden*/
private boolean isOpen;

/**Speicher die Verbungsdaten*/
private Connection con;

/**Zeigt die Anzahl der Datensätze, die maximal auf einmal geholt werden können,
* bei 0 wird keine Beschränkung auferlegt*/
public final static int ANZ_DATENSAETZE = 10000;

private ResultSet rs;

private Statement stmt;


/**
* Konstruktor
*
* baut die Verbindung auf und fragt die Daten ab.
*
* @param t - treiber über den JDBC die verbindung herstellt
* @param url - entweder die URl oder die DSN bei ODBC verbindungen

*/

public DatenbankS(Treiber t, String url) {

this.url = t.getConnection() + url;
treiber = t.getTreiber();
zeilen = 0;
spalten = 0;
error = "";
status = true;
isOpen = false;

}//Datenbankverbindung



/**
* baut die Verbindung auf und fragt die Daten ab.
*
* @param query - erwartet den Abfrage String
* @param url - die ODBC Verbindung
* @param user - benutzername
* @param pw - passwort
*
*/
public void connect(String user, String pw){

this.user = user;
this.pw = pw;

//!!!!ACHTUNG!!!! UNTERSCHEIDUNG DER ABFRAGEN NOCH VON NÖTEN -z.Zt. nur Select
try {
//Load the jdbc-odbc bridge driver
Class.forName (treiber);
//DriverManager.setLogStream(System.out);

//Connect zum ODBC Treiber
con =
DriverManager.getConnection (url,this.user,this.pw);
//con.setAutoCommit(false);
isOpen = true;

//wenn kein Connectivität, dann hier exception
checkForWarning (con.getWarnings ());

}//try
catch (SQLException ex) {
status = false;
System.out.println ("\n*** SQLException caught ***\n");
while (ex != null) {
System.out.println ("SQLState: " +
ex.getSQLState ());
System.out.println ("Message: " + ex.getMessage ());
error = "Fehler bei SELECT: "+ex.getMessage();
System.out.println ("Vendor: " +
ex.getErrorCode ());
ex = ex.getNextException ();
System.out.println ("");
}//while
}//catch
catch (java.lang.Exception ex) {
//evtentuell andere Exceptions
ex.printStackTrace ();
}//catch
}//connect

/**
* baut die Verbindung auf und fragt die Daten ab.
*
* @param query - erwartet den Abfrage String
* @param url - die ODBC Verbindung
* @param user - benutzername
* @param pw - passwort
*
*/
public boolean abfragen(String query){

//speichert die Query für die Count anweisung
this.query = query;



if(!check())return false;

//!!!!ACHTUNG!!!! UNTERSCHEIDUNG DER ABFRAGEN NOCH VON NÖTEN -z.Zt. nur Select
try {

//Anzeigen welche Verbindung es ist, damit, richtige Abfarge errstellt werden kann
stmt = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);

if(!(ANZ_DATENSAETZE == 0))stmt.setMaxRows(ANZ_DATENSAETZE);
//Schickt anfrage zur Datenbank - und speichert sie im resultset
rs = stmt.executeQuery(this.query);
//temp = rs.

rs.last();
zeilen = rs.getRow();
rs.beforeFirst();

int pos = 0;
String out;
//speichert lesbare DATEN in rsmd
ResultSetMetaData rsmd = rs.getMetaData ();

//anzahl der Spalten
spalten = rsmd.getColumnCount ();

datensatz = new String[spalten][zeilen];
//zeilenzeiger wieder an die erste Pos
boolean more = rs.next();
//solange noch zeilen vorhanden sind, lese sie aus
while (more) {
pos++;
for (int i=1; i<=spalten; i++) {
out = rs.getString(i);
datensatz[i-1][pos-1] = out;
}//for
more = rs.next ();
}//while
rs.close();


//Close the statement
this.stmt.close();
System.gc();
isOpen = true;

}//try
catch (SQLException ex) {
status = false;
System.out.println ("\n*** SQLException caught ***\n");
while (ex != null) {
System.out.println ("SQLState: " +
ex.getSQLState ());
System.out.println ("Message: " + ex.getMessage ());
error = "Fehler bei SELECT: "+ex.getMessage();
System.out.println ("Vendor: " +
ex.getErrorCode ());
ex = ex.getNextException ();
System.out.println ("");
}//while
}//catch
catch (java.lang.Exception ex) {
//evtentuell andere Exceptions
ex.printStackTrace ();
}//catch

return true;
//test();
}//connect

/**
* schliesst die Verbindung
*
*/
public void disconnect(){

try {
if(!con.isClosed()){

//Close the connection
con.close();
isOpen = false;//isOpen
}//if
}//try
catch (SQLException ex) {
status = false;
System.out.println ("\n*** SQLException caught ***\n");
while (ex != null) {
System.out.println ("SQLState: " +
ex.getSQLState ());
System.out.println ("Message: " + ex.getMessage ());
error = "Fehler bei INSERT: "+ex.getMessage();
System.out.println ("Vendor: " +
ex.getErrorCode ());
ex = ex.getNextException ();
System.out.println ("");
}//while
}//catch
catch (java.lang.Exception ex) {
//evtentuell andere Exceptions
ex.printStackTrace ();
}//catch

}//disconnect



/**
* Wenn die ersten Zeichen eine korrekte Anweisung enthalten, so wird true zurück
* gegeben und die Art der Anweisung gespeichert!
*
* @return ob der Abfrage String eine Select anweisung ist
*/
private boolean check(){

if(query.substring(0,6).toUpperCase().equals("SELECT")){
return true;
}//if

error = "Fehler bei SELECT: Die Abfrage war keine gültige Abfrabe, überprüfen Sie diese";
status = false;
return false;

}//

/**
* Erzeugt eine Warnmeldung oder Info vom SQL Server mit Ausgabe
* @param warn - die Warnmeldung
* @throws SQLException
*/
private static void checkForWarning (SQLWarning warn)throws SQLException {
if (warn != null) {
System.out.println ("\n *** Warning ***\n");
while (warn != null) {
System.out.println ("SQLState: " +
warn.getSQLState ());
System.out.println ("Message: " +
warn.getMessage ());
System.out.println ("Vendor: " +
warn.getErrorCode ());
System.out.println ("");
warn = warn.getNextWarning ();
}//while
}//if
}//checkForWaring


/**
* Does ...
*
*
* @return
*/
public String[][] getDaten() {
// your code here
return datensatz;
}

/**
*
* @return die Anuahl der Zeilen
*/
public int getZeilen() {
// your code here
return zeilen;
}

/**
*
* @return die Anzahl der Spalten
*/
public int getSpalten() {
// your code here
return spalten;
}

/**
* Zeigt an, ob die Abfarge fehlerfrei verlaufen ist
*
*
* @return true- wenn die Abfrage fehlerfrei war
*/
public boolean getStatus() {
// your code here
return status;
}

/**
* gibt, wenn vorhanden, die SQL Fehlermeldung zurück
* @return Fehlermeldung
*/
public String getFehler(){
return error;
}//

/**
* gibt zurück, ob bereits eine offene Verbindung besteht
*
* @return true/false
*/
public boolean isOpen(){
return isOpen;
}//isOpen
}


 Auf diesen Beitrag antworten
 Neuen Beitrag verfassen


|<   <   >   >|

                                                                                                                                                                                                                           

Impressum  · Datenschutz  · AGB  · Infos  · Presse
Ein modernes Forum: teamturn.com