Pagina 1 di 2 1 2 ultimoultimo
Visualizzazione dei risultati da 1 a 10 su 12
  1. #1
    Utente di HTML.it
    Registrato dal
    Jan 2010
    Messaggi
    26

    [JAVA - MYSQL] Problema con i Driver per la connessione

    Salve a tutti!
    Sono nuovo del forum (e già ho delle rogne da proporvi :P).Sto iniziando a usare i database in java, ma ho dei problemi a connettermi con un db mysql. Utilizzo il phpadmin di easyphp per creare il db, lo aggiungo alle fonti odcb con il connector mysql, ma niente, non si connette!. Di seguito il codice:

    Codice:
    codice:
    class Database {
       private String nomeDB;       // Nome del Database a cui connettersi
       private String nomeUtente;   // Nome utente utilizzato per la connessione al Database
       private String pwdUtente;    // Password usata per la connessione al Database
       private String errore;       // Raccoglie informazioni riguardo l'ultima eccezione sollevata
       private Connection db;       // La connessione col Database
       private boolean connesso;    // Flag che indica se la connessione è attiva o meno
    
       public Database(String nomeDB) { this(nomeDB, "", ""); }
    
       public Database(String nomeDB, String nomeUtente, String pwdUtente) {
          this.nomeDB = nomeDB;
          this.nomeUtente = nomeUtente;
          this.pwdUtente = pwdUtente;
          connesso = false;
          errore = "";
       }
    
       // Apre la connessione con il Database
       public boolean connetti() {
          connesso = false;
          try {
    
             // Carico il driver JDBC per la connessione con il database MySQL
             Class.forName("com.mysql.jdbc.Driver");
    
             // Controllo che il nome del Database non sia nulla
             if (!nomeDB.equals("")) {
    
                // Controllo se il nome utente va usato o meno per la connessione
                if (nomeUtente.equals("")) {
    
                   // La connessione non richiede nome utente e password
                   db = DriverManager.getConnection("jdbc:mysql://localhost/" + nomeDB);
                } else {
    
                   // La connessione richiede nome utente, controllo se necessita anche della password
                   if (pwdUtente.equals("")) {
    
                      // La connessione non necessita di password
                      db = DriverManager.getConnection("jdbc:mysql://localhost/" + nomeDB + "?user=" + nomeUtente);
                   } else {
    
                      // La connessione necessita della password
                      db = DriverManager.getConnection("jdbc:mysql://localhost/" + nomeDB + "?user=" + nomeUtente + "&password=" + pwdUtente);
                   }
                }
    
                // La connessione è avvenuta con successo
                connesso = true;
             } else {
                System.out.println("Manca il nome del database!!");
                System.out.println("Scrivere il nome del database da utilizzare all'interno del file \"config.xml\"");
                System.exit(0);
             }
          } catch (Exception e) { errore = e.getMessage(); }
          return connesso;
       }
    
       // Esegue una query di selezione dati sul Database
       // query: una stringa che rappresenta un'istruzione SQL di tipo SELECT da eseguire
       // colonne: il numero di colonne di cui sarà composta la tupla del risultato
       // ritorna un Vector contenente tutte le tuple del risultato
       public Vector eseguiQuery(String query) {
          Vector v = null;
          String [] record;
          int colonne = 0;
          try {
             Statement stmt = db.createStatement();     // Creo lo Statement per l'esecuzione della query
             ResultSet rs = stmt.executeQuery(query);   // Ottengo il ResultSet dell'esecuzione della query
             v = new Vector();
             ResultSetMetaData rsmd = rs.getMetaData();
             colonne = rsmd.getColumnCount();
    
             while(rs.next()) {   // Creo il vettore risultato scorrendo tutto il ResultSet
                record = new String[colonne];
                for (int i=0; i<colonne; i++) record[i] = rs.getString(i+1);
                v.add( (String[]) record.clone() );
             }
             rs.close();     // Chiudo il ResultSet
             stmt.close();   // Chiudo lo Statement
          } catch (Exception e) { e.printStackTrace(); errore = e.getMessage(); }
    
          return v;
       }
    
       // Esegue una query di aggiornamento sul Database
       // query: una stringa che rappresenta un'istuzione SQL di tipo UPDATE da eseguire
       // ritorna TRUE se l'esecuzione è adata a buon fine, FALSE se c'è stata un'eccezione
       public boolean eseguiAggiornamento(String query) {
          int numero = 0;
          boolean risultato = false;
          try {
             Statement stmt = db.createStatement();
             numero = stmt.executeUpdate(query);
             risultato = true;
             stmt.close();
          } catch (Exception e) {
             e.printStackTrace();
             errore = e.getMessage();
             risultato = false;
          }
          return risultato;
       }
    
       // Chiude la connessione con il Database
       public void disconnetti() {
          try {
             db.close();
             connesso = false;
          } catch (Exception e) { e.printStackTrace(); }
       }
    
       public boolean isConnesso() { return connesso; }   // Ritorna TRUE se la connessione con il Database è attiva
       public String getErrore() { return errore; }       // Ritorna il messaggio d'errore dell'ultima eccezione sollevata
    }

    e qui il main:
    Codice:
    codice:
        
    public class ProvaMySQL{
    
        
        public static void main(String args[])throws SQLException{
        
            Database db = new Database("magazzino");
            if ( !db.connetti() ) {
                System.out.println("Errore durante la connessione.");
                System.out.println( db.getErrore() );
                System.exit(0);
            
            }
    
            // Eseguo una query sul database. La tabella si chiama album.
            Vector v = db.eseguiQuery( "SELECT * FROM album;" );
    
            // Stampiamo i risultati:
            int i = 0;
            while ( i<v.size() ) {
                String[] record = (String[]) v.elementAt(i);
                System.out.println("Record numero " + (i+1) );
                for (int j=0; j<record.length; j++) {
                    System.out.println( record[j] );
                }
            }
    
            // Eseguo un aggiornamento sul campo 'nomecampo' della tabella album:
            if ( !db.eseguiAggiornamento("UPDATE album SET nomecampo=valore WHERE nomecampo>0;") ) {
                System.out.println("Errore nell'aggiornamento!");
                System.out.println( db.getErrore() );
            }    
    
            // Ora chiudo la connessione col Database:
            db.disconnetti();         
        
        
        }    
      }
    Grazie!!!

  2. #2
    in
    codice:
    jdbc:mysql://localhost/
    manca la porta, riprova con

    codice:
    jdbc:mysql://localhost:3306/
    oppure la 3307

    e se ti dà ancora errore posta anche l'eccezione

  3. #3
    Utente di HTML.it
    Registrato dal
    Jan 2010
    Messaggi
    26
    Niente

    codice:
    Errore durante la connessione. 
    com.mysql.jdbc.Driver

  4. #4
    cambia

    codice:
    catch (Exception e) { errore = e.getMessage(); }
    in public boolean connetti()

    con

    codice:
    catch (Exception e) { e.printStackTrace(); }
    e riprova così vediamo tutto lo stack trace senno si và alla cieca

  5. #5
    Utente di HTML.it
    Registrato dal
    Jan 2010
    Messaggi
    26
    codice:
    C:\Documents and Settings\Aldo Mollica\Desktop>java ProvaMySQL
    java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
            at java.net.URLClassLoader$1.run(Unknown Source)
            at java.security.AccessController.doPrivileged(Native Method)
            at java.net.URLClassLoader.findClass(Unknown Source)
            at java.lang.ClassLoader.loadClass(Unknown Source)
            at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
            at java.lang.ClassLoader.loadClass(Unknown Source)
            at java.lang.ClassLoader.loadClassInternal(Unknown Source)
            at java.lang.Class.forName0(Native Method)
            at java.lang.Class.forName(Unknown Source)
            at Database.connetti(ProvaMySQL.java:33)
            at ProvaMySQL.main(ProvaMySQL.java:135)
    Errore durante la connessione.
    Errore del driver jdbc a quanto pare...

  6. #6
    java.lang.ClassNotFoundException non riesce a trovare il driver JDBC per mysql
    se non l'hai già fatto scaricalo da
    qui
    e assicurati che java lo trovi (deve stare nel classpath)

  7. #7
    Utente di HTML.it
    Registrato dal
    Jan 2010
    Messaggi
    26
    Scaricato e creato il CLASSPATH del .jar, ma da il medesimo errore.

  8. #8
    quando dici "creato il CLASSPATH del .jar" cosa intendi ? prova a mettere il jar dei driver nella stessa cartella del tuo file class e fare

    java -classpath nomedeljardeidrivermysql.jar ProvaMySQL

  9. #9
    Utente di HTML.it
    Registrato dal
    Jan 2010
    Messaggi
    26
    Intendo che l'ho aggiunta come variabile d'ambiente. Cmq scrivendo java -classpath nomedeljardeidrivermysql.jar ProvaMySQL , ma mi genera il medesimo errore

    codice:
    Exception in thread "main" java.lang.NoClassDefFoundError: ProvaMySQL
    Caused by: java.lang.ClassNotFoundException: ProvaMySQL
            at java.net.URLClassLoader$1.run(Unknown Source)
            at java.security.AccessController.doPrivileged(Native Method)
            at java.net.URLClassLoader.findClass(Unknown Source)
            at java.lang.ClassLoader.loadClass(Unknown Source)
            at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
            at java.lang.ClassLoader.loadClass(Unknown Source)
            at java.lang.ClassLoader.loadClassInternal(Unknown Source)
    Could not find the main class: ProvaMySQL.  Program will exit.

  10. #10
    ........

Permessi di invio

  • Non puoi inserire discussioni
  • Non puoi inserire repliche
  • Non puoi inserire allegati
  • Non puoi modificare i tuoi messaggi
  •  
Powered by vBulletin® Version 4.2.1
Copyright © 2025 vBulletin Solutions, Inc. All rights reserved.