Visualizzazione dei risultati da 1 a 9 su 9
  1. #1

    driver mysql

    ciao a tutti! ho letto la pillola di leleFt riguardo alla connessione di java ad un database MySql.... tento di connettermi ad un database locale che gestisco con phpmyAdmin ma purtroppo incappo nel seguente errore:

    Errore durante la connessione.
    Error during query: Unexpected Exception: java.io.CharConversionException message given: null

    Nested Stack Trace:


    ** BEGIN NESTED EXCEPTION **

    java.io.CharConversionException

    STACKTRACE:

    java.io.CharConversionException
    at gnu.gcj.convert.Input_iconv.read(natIconv.cc:99)
    at java.lang.String.init(natString.cc:496)
    at java.lang.String.<init>(String.java:296)
    at com.mysql.jdbc.SingleByteCharsetConverter.<init>(S ingleByteCharsetConverter.java:153)
    at com.mysql.jdbc.SingleByteCharsetConverter.initChar set(SingleByteCharsetConverter.java:108)
    at com.mysql.jdbc.SingleByteCharsetConverter.getInsta nce(SingleByteCharsetConverter.java:86)
    at com.mysql.jdbc.Connection.getCharsetConverter(Conn ection.java:3471)
    at com.mysql.jdbc.StringUtils.getBytes(StringUtils.ja va:609)
    at com.mysql.jdbc.Buffer.writeStringNoNull(Buffer.jav a:655)
    at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java :1678)
    at com.mysql.jdbc.Connection.execSQL(Connection.java: 3243)
    at com.mysql.jdbc.Connection.configureClientCharacter Set(Connection.java:2509)
    at com.mysql.jdbc.Connection.initializePropsFromServe r(Connection.java:4096)
    at com.mysql.jdbc.Connection.createNewIO(Connection.j ava:2756)
    at com.mysql.jdbc.Connection.<init>(Connection.java:1 553)
    at com.mysql.jdbc.NonRegisteringDriver.connect(NonReg isteringDriver.java:266)
    at java.sql.DriverManager.getConnection(DriverManager .java:165)
    at java.sql.DriverManager.getConnection(DriverManager .java:204)
    at Database.connetti(Database.java:50)
    at Database.main(Database.java:130)


    ** END NESTED EXCEPTION **

    Il codice della classe (praticamente invariato dalla pillola) è:

    codice:
    * Classe dedicata alla gestione del Database.
    	 * Gestisce l'apertura e la chiusura della connessione col Database
    	 * Fornisce i metodi per l'esecuzione delle query sul Database
    	 */
    	import java.sql.*;
    import java.util.Vector;
    
    	public 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").newInstance();
    
    	         // 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
    	   
    	   public static void main(String[] args) {
    			
    			Database db = new Database("prova","root","");
    			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 Tbl.
    			Vector v = db.eseguiQuery( "SELECT * FROM p;" );
    
    //			 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 Tbl:
    			if ( !db.eseguiAggiornamento("UPDATE Tbl 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();
    			
    		}
    	}
    So che l'argomento è stato molto spesso trattato, ma proprio non riesco a capire dove sbaglio.
    Spero riusciate a darmi una mano

  2. #2
    nessuno sa darmi una mano?? davvero non so come risolvere.... uso eclipse su linux e non riesco a capire se l'errore possa dipendere da quello....
    fatemi sapere qualcosa!

  3. #3
    Utente di HTML.it
    Registrato dal
    Apr 2007
    Messaggi
    906
    Qual'e' di preciso la riga 50 nel codice (sarebbe quella che ti da errore)?
    Se conto nel codice che hai postato mi cade su una riga vuota.

  4. #4
    ciao! grazie per aver risposto... la riga 50 è questa:

    db = DriverManager.getConnection("jdbc:mysql://localhost/" + nomeDB + "?user=" + nomeUtente);

    Confido nelle tue conoscenze!

  5. #5
    Utente di HTML.it
    Registrato dal
    Apr 2007
    Messaggi
    906
    Sembra un problema di codifica dei caratteri tra jvm e S.O. Butto li la mia ipotesi.
    Hai detto che usi linux, probabilmente e' una distribuzione tipo Fedora, Red Hat o simili che invece di usare la jvm della sun, ne usano una tutta loro(che purtroppo a volte da problemi).
    Io istallerei la jvm ufficiale della sun per linux e direi ad eclipse di utilizzare quella.
    Sono abbastanza sicuro che il problema dopo non si presenti piu'.

  6. #6
    grazie! io uso ubuntu... provo a guardare se il problema sia quello... spero di riuscire a risolvere

  7. #7
    ciao! ho controllato la virtual machine, anche specificando ad eclipse di usare quella della sun, ma non c'è verso di far scomparire l'errore.... avete idea da cosa possa dipendere?!?

  8. #8
    Utente di HTML.it
    Registrato dal
    Apr 2007
    Messaggi
    906
    L'errore e' sempre lo stesso?
    Se continua a comparire la riga "at gnu.gcj.convert.Input_iconv.read(natIconv.cc:99)" nella pila dell'eccezione, vuol dire che continua ad usare componenti della vm di linux o librerie non ufficiali.
    Se per te non e' un problema, rimuovi dal sistema le componenti java preesistenti, scaricati il JDK per linux dal sito della sun e lascia solo quello.
    Ho guardato anche in giro sul web: il problema si presenta solo su sistemi linux e la soluzione proposta e' sempre la stessa. Rimuovere il JDK di linux ed istallare il JDK ufficiale della sun.
    Spero che il tuo problema si risolva presto.

  9. #9
    grazie mille! anch'io alla disperata ricerca per i forum sono arrivato alla stessa conclusione.... non mi rimane che reinstallare il tutto
    ciao!

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.