absolute beginner . wie klassen strukturieren

Status
Nicht offen für weitere Antworten.
L

LostInJava

Gast
Hallo,

ich fange grad mit Java an und bin gleich verloren gegangen im Dschungel von Klassen, Methoden, Variablen...

Meine Aufgabe ist ein Datentransfer zwischen zwei Datenbanken. Also habe ich ueberlegt, ich brauche drei Objekte. 1. Objekt Source mit den Attributen (tblName, colName, timeID + persID (= die reihe die ich haben will)) , 2. Objekt Destination (tblName, colName) und das 3. Objekt DataTransfer (conSrc, conStrSrc, conDest, conStrDest ( weil ich brauch ja zwei Verbindungen ), sqlQuery (um einen Datensatz auszulesen), sqlInsert (um ihn in die andere Datenbank zu schreiben) als Methoden (getValue (oeffne verbindung 1 und leses daten aus Source) und performTransfer (oeffne verbingung zwei und schreibe in destination)

Naja, schoen gedacht, ich leg los und stell auf einmal fest das das vorne und hinten nicht stimmt. macht es ueberhaupt sinn, drei klassen zu haben, oder soll ich alles in einer machen. ( ich weiss nicht, ob das wichtig ist fuer die entscheidung, vorerst soll das statisch passieren (also tblName=wasweissich) und spaeter dynamisch auf grund einer bestimmten configuration)

Waer toll, wenn mir jemand zurueck in die Spur helfen koennte, und mir nen Tipp geben, wie Objekte, Klassen, Methoden strukturieren.

Vielen Dank fuer Eure Hilfe
Peace out ,
TotallyLost
 

André Uhres

Top Contributor
Ich hatte mal diesen SQLWorker programmiert, vielleicht kannst du ja damit etwas anfangen :wink:
Code:
package swing02;
import java.sql.*;
import javax.swing.*;
import javax.swing.table.*;
public class SQLWorker implements Runnable{
/* Beispiel für die Benutzung dieser Klasse:
        //////////////////////////
        JTable resultset = new JTable(0,5); //5=Anzahl Spalten !
        SQLWorker.runSQL(new Thread( new SQLWorker( "SELECT * FROM " + TABLE_NAME, resultset, DATABASE_NAME ) ));
//        scrollpane.setViewportView(resultset);
        for( int row=0; row<resultset.getRowCount(); row++ ){
            String host         = resultset.getValueAt( row, SQLWorker.column(resultset,"host") ).toString();
            String db           = resultset.getValueAt( row, SQLWorker.column(resultset,"db") ).toString();
            String tablename    = resultset.getValueAt( row, SQLWorker.column(resultset,"table_name") ).toString();
            System.out.println(host+"\t"+db  +"\t"+tablename  );
        }
        /////////////////////////
        SQLWorker.runSQL(new Thread( new SQLWorker(
                "INSERT INTO " + TABLE_NAME +
                " (Host,Db,User,Table_name,Grantor) " +
                "values ( ''" +
                ", '" + resultset.getValueAt(0, 1).toString()+"'" +
                ", '" + resultset.getValueAt(0, 2).toString()+"'" +
                ", '" + resultset.getValueAt(0, 3).toString()+"'" +
                ", '" + resultset.getValueAt(0, 4).toString()+"'" +
                " )", null, DATABASE_NAME2 ) ));
        /////////////////////////
 */    
    public SQLWorker(String query, JTable displayTable, String databaseName) {
        this.query = query;
        this.displayTable = displayTable;
        this.databaseName = databaseName;
        databaseURL = databaseURL + databaseName;
        if(displayTable != null)
            displayTableModel = (DefaultTableModel)displayTable.getModel();
    }
    public void run(){
        try{
            DriverManager.registerDriver( new com.mysql.jdbc.Driver() );
            DriverManager.registerDriver( new sun.jdbc.odbc.JdbcOdbcDriver() );
            connection = DriverManager.getConnection(databaseURL, DATABASE_USER, USER_PASSWORD);
            System.out.println("Successfully connected");
        }catch(SQLException ex){
            System.out.println("Connection failed");
            System.out.println( ex.getMessage() );
        }
        try{
            doSQL();
        }catch(SQLException ex){
            System.out.println( ex.getMessage() );
        }
        System.out.println("done!");
    }
    private void doSQL() throws SQLException{
        try {
            if(connection!=null){
                statement = connection.createStatement();
                String queryU = query.substring(0,10).toUpperCase();
                if(!queryU.contains("SELECT")){
                    statement.executeUpdate(query);
                }else{
                    resultset = statement.executeQuery(query);
                    dispResultSet(resultset);
                }
            }
        }finally{
            if(resultset!=null)resultset.close();
            if(statement!=null)statement.close();
            if(connection!=null)connection.close();
        }
    }
    private void dispResultSet(final ResultSet resultset) throws SQLException{
        int i;
        ResultSetMetaData rsmd = resultset.getMetaData();
        int numCols = rsmd.getColumnCount();
        // Display column headings
        for (i=1; i<=numCols ; i++) {
            tablecolumn = displayTable.getColumnModel().getColumn(i-1);
            tablecolumn.setHeaderValue( rsmd.getColumnLabel(i).toString() );
        }
        // Display data, fetching until end of the result set
        boolean more = resultset.next();
        while ( more ) {
            // Loop through each column, getting the column data and displaying
            Object[] rowData = new Object[numCols];
            for (i=1; i<=numCols; i++) {
                rowData[i-1] = resultset.getString(i);
            }
            displayTableModel.addRow(rowData);
            // Fetch the next result set row
            more = resultset.next();
        }
    }
    public static void runSQL(Thread queryWorker){
        queryWorker.start();
        for( int i=0; queryWorker.isAlive() && i<100; i++ ){
            try{
                Thread.sleep(100);
            }catch(InterruptedException ex){}
        }
    }
    
    public static int column(final JTable displayTable, final String columnName){
        int col=0;
        int numCols = displayTable.getColumnCount();
        for( ; col < numCols; col++ ){
            TableColumn tablecolumn = displayTable.getColumnModel().getColumn(col);
            if( columnName.equalsIgnoreCase( tablecolumn.getHeaderValue().toString() ) ) {
                break;
            }
        }
        return col;
    }
    private String query;
    private JTable displayTable;
    private DefaultTableModel displayTableModel ;
    private TableColumn tablecolumn ;
    private Connection connection;
    private Statement statement;
    private ResultSet resultset;
    private String databaseName;
//    private final String databaseURL =  "jdbc:mysql://localhost:3306/";
    private String databaseURL = "jdbc:odbc:";
    private final String DATABASE_USER = "root";
    private final String USER_PASSWORD = "sql";
}
 

dhachim

Bekanntes Mitglied
da haste dir aber gleich was richtig dolles ausgesucht. hast du schon OOP erfahrung ?
Wenn nicht rate ich dir davon ab einfach blind draufloszurennnen. Am Anfang wird das noch gut gehen, aber später wird sich das rächen wenn die Programme komplexer werden.

Also mehrere Klassen sind sehr sinnvoll, um später noch nen Überblick zu behalten.
Und das mit dem statischem und später flexiblen inhalten lässt sich hervorragend über die Klasse Properties lösen.
das ist ein txt file, in dem man konfigurationen festlegen kann.

Und sonst rate ich dir langsam anzufangen.
http://www.gailer-net.de/tutorials/java/java-toc.html
das ist ein recht gutes tutorial zum einstieg in Java und die OOP.

Dir jetzt konkrete Programmteile zu liefern würde dich net weiterbringen.. fang mal an wenn du irgendwo nen Problem hast poste es und hier wird dir geholfen.

Gruß Daniel :meld:
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
U Absolute path funktioniert nicht Java Basics - Anfänger-Themen 5
O Absolute Pfade in mehrere Klassen verwenden Java Basics - Anfänger-Themen 3
L Manifest und absolute Pfade Java Basics - Anfänger-Themen 5
T Aufrufen von get-Methode aus anderer Klasse (absolute Anfängerfrage) Java Basics - Anfänger-Themen 2
B Relative/Absolute Pfadangabe. Wie unterscheiden? Java Basics - Anfänger-Themen 4
G absolute Häufigkeit Java Basics - Anfänger-Themen 13
H Absolute null ersetzen Java Basics - Anfänger-Themen 2
P Absolute Verzweiflung: Linux + Java + CLASSPATH Java Basics - Anfänger-Themen 8
C Absolute Cursor Position oder doch relative? Java Basics - Anfänger-Themen 4
S Wie bekomme ich absolute Werte (Betrag einer Zahl)? Java Basics - Anfänger-Themen 5
B Sodoku vs. Beginner Java Basics - Anfänger-Themen 3
S Beginner: Text formatiert speichern Java Basics - Anfänger-Themen 7
L Java [Beginner] Problem Java Basics - Anfänger-Themen 8
G Absolut Beginner: sh in bat umwandeln Java Basics - Anfänger-Themen 6
P Java beginner - Buch: Java- Einstieg für Anspruchsvolle Java Basics - Anfänger-Themen 6
V Beginner question with check true value??? Java Basics - Anfänger-Themen 3
T Absolut Beginner auf nem MAC OS 9.2 Java Basics - Anfänger-Themen 2
J Methodenaufrufe abstrakte Klassen, Interfaces Java Basics - Anfänger-Themen 17
M Abstrakte Klassen - Notation Java Basics - Anfänger-Themen 9
Detlef Bosau Nachladen von Klassen zur Laufzeit Java Basics - Anfänger-Themen 24
M Anonyme Klassen - Warum wird in der Konsole nichts ausgegeben? Java Basics - Anfänger-Themen 1
MoxMorris Einige Methoden aus verschiedenen Klassen nacheinander auszuführen läuft seltsam Java Basics - Anfänger-Themen 2
I Klassen von einem package laden, Statisches Feld auslesen und Objekt erstellen Java Basics - Anfänger-Themen 8
I 2 verschiedene Klassen mit gleichen Property vergleichen Java Basics - Anfänger-Themen 13
C Array von Klassen Java Basics - Anfänger-Themen 2
monsterherz 2 Klassen daher Probs mit dem Dateinamen Java Basics - Anfänger-Themen 9
C Kommunikation zwischen 2 Klassen Java Basics - Anfänger-Themen 9
I JPA Query für mehrere Klassen Java Basics - Anfänger-Themen 3
I @Entity Klassen, Service Beans etc. aus einem Share Projekt beziehen? Java Basics - Anfänger-Themen 26
S IntelliJ geht alle Klassen durch Java Basics - Anfänger-Themen 9
I Gleiche Klassen und Methoden in unterschiedlichen Projekten nutzen Java Basics - Anfänger-Themen 2
T variablen klassen übergreifend Java Basics - Anfänger-Themen 12
N Klassen Methoden anderer Klassen aufrufen Java Basics - Anfänger-Themen 4
D Klassen Klassen Kommunikation Java Basics - Anfänger-Themen 12
Encera Auf Objekte aus anderer Klassen zugreifen Java Basics - Anfänger-Themen 20
berserkerdq2 Zwei Klassen Erben von der Klasse A, die eine Klasse kann ich an Methoden übergeben, die als Parameter A haben, die andere nicht? Java Basics - Anfänger-Themen 3
M Andere Methoden in anderen Klassen aufrufen Java Basics - Anfänger-Themen 11
L Methoden in anderen Klassen nutzen Java Basics - Anfänger-Themen 6
D Klassen und Vererbung Java Basics - Anfänger-Themen 2
L Best Practice Annotierte Klassen im Classpath herausfinden Java Basics - Anfänger-Themen 1
P Mit dem Scanner Klassen aufrufen Java Basics - Anfänger-Themen 3
O Klassen Zusammenspiel zwischen 2 Klassen Java Basics - Anfänger-Themen 1
K Zweite Ausgabe von vererbten Klassen Java Basics - Anfänger-Themen 3
M Wie können Klassen nicht-materialisierte Attribute haben, die nur über get/ set-Mehoden simuliert sind? Java Basics - Anfänger-Themen 6
Speedrunner klassen aufrufen Java Basics - Anfänger-Themen 41
M Log4J (v2) nachträglich in allen Klassen hinzufügen Java Basics - Anfänger-Themen 9
D importieren eigener Klassen Java Basics - Anfänger-Themen 12
W Wo ist der Wurm in meinem Grundverständnis von Klassen? Java Basics - Anfänger-Themen 22
S Daten/Klassen/Packages richtig updaten!? Java Basics - Anfänger-Themen 2
alice98 Erste Schritte Liste erstellen ohne vorgefertigte Klassen Java Basics - Anfänger-Themen 1
C Archiv für eigene Klassen Java Basics - Anfänger-Themen 9
S Objekte von zwei klassen in zwei verschiedene Textdateien schreiben Java Basics - Anfänger-Themen 5
elsaaaaaa Wochentag als String ausgeben mit JDK Klassen Java Basics - Anfänger-Themen 6
CptK Generics: Klassen die Interface implementieren, aber selbst nicht das Interface sind Java Basics - Anfänger-Themen 8
Z Mehtode bei Start des Programms ausführen (Klassen übergreifend) Java Basics - Anfänger-Themen 12
J Allgemeines Problem mit Klassen Java Basics - Anfänger-Themen 5
TimoN11 Java Klassen Global einbinden Java Basics - Anfänger-Themen 1
B Inventar als einzelne Klassen anlegen? Java Basics - Anfänger-Themen 12
G Java Klassen und Instanzmethoden Java Basics - Anfänger-Themen 15
C Kommunikation zwischen 2 Klassen Java Basics - Anfänger-Themen 3
T Vererbung Verschiedene Attribute für vererbte Klassen Java Basics - Anfänger-Themen 4
S Klassen instanziieren und verwenden von Getter und Setter Java Basics - Anfänger-Themen 4
B Variablen Variablen übertragen ohne Klassen Java Basics - Anfänger-Themen 5
C Fernseher-Aufgabe (Methoden, Klassen und Objekte) Java Basics - Anfänger-Themen 63
H Methoden in großen Klassen gruppieren oder auslagern? Java Basics - Anfänger-Themen 10
G Abstrakte Klassen Java Basics - Anfänger-Themen 11
Y Klassen Klassen und Objekte Java Basics - Anfänger-Themen 3
Y Klassen Klassen und Objekte mit set und get Java Basics - Anfänger-Themen 0
A Generischen Klassen Java Basics - Anfänger-Themen 8
A Vererbung Klassen im Bezug auf Auto´s Java Basics - Anfänger-Themen 18
A Generische Klassen/Interface Java Basics - Anfänger-Themen 1
A Klassen Vererbung und zusätzliche Unterklassen Java Basics - Anfänger-Themen 23
J 2 klassen benutzen Java Basics - Anfänger-Themen 5
A Klassen und methoden Java Basics - Anfänger-Themen 15
A Bankweverwaltung mit Klassen und Methoden Java Basics - Anfänger-Themen 14
J Klassen Problem Java Basics - Anfänger-Themen 8
I Java Klassen "Graphics" und "MouseEvent" kombinieren Java Basics - Anfänger-Themen 7
I Klassen als Datentyp nutzen? Java Basics - Anfänger-Themen 11
M Aufsplitten von Methoden in andere Klassen Java Basics - Anfänger-Themen 2
M (Sehr großes Problem) Listen als static in anderen Klassen verwendet Java Basics - Anfänger-Themen 12
C Klassen objektorientiert aufteilen Java Basics - Anfänger-Themen 6
hello_autumn Klassen Anzahl sowie die Anzahl der Junit Tests ermitteln? Java Basics - Anfänger-Themen 8
A Auf Eigenschaften von Objekten anderer Klassen zugreifen Java Basics - Anfänger-Themen 5
F Klassen und Pakete Projektübergreifend (Eclipse) Java Basics - Anfänger-Themen 6
V_Fynn03 Klassen Überweisungen tätigen und einzahlen mit 2 Klassen Java Basics - Anfänger-Themen 1
W Abarbeitungsreihenfolge Anonyme Klassen Java Basics - Anfänger-Themen 2
V_Fynn03 Bruchrechner programmieren (2 Klassen) Java Basics - Anfänger-Themen 9
D OOP- Eine Klasse in mehrere Klassen aufteilen Java Basics - Anfänger-Themen 7
J Problem mit Array: 2 Klassen Java Basics - Anfänger-Themen 2
W Frage zu anonymen Klassen Java Basics - Anfänger-Themen 4
Curtis_MC Parameter-Übergabe bei Klassen und Methoden Java Basics - Anfänger-Themen 12
E Klassen implementieren Java Basics - Anfänger-Themen 94
T Interfaces in erbenden Klassen Java Basics - Anfänger-Themen 2
C Methoden/Klassen Übergabewerte Java Basics - Anfänger-Themen 8
C Java Klassen/Methoden/Übergabeparameter Java Basics - Anfänger-Themen 4
L Wie geht man bei mehreren Action Klassen vor? Java Basics - Anfänger-Themen 0
P Datentypen, Klassen, Operatoren, Wrapperklassen Java Basics - Anfänger-Themen 2
L Wie teilt man ein Programm in vernünftige Klassen ein? Java Basics - Anfänger-Themen 10
T Klassen Denkfehler im Klassen "dynamisch" instanzieren? Java Basics - Anfänger-Themen 4
P Zugriff auf Variablen anderer Klassen in Greenfoot Java Basics - Anfänger-Themen 1

Ähnliche Java Themen

Neue Themen


Oben