Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Pannello QD-OLED da 32 pollici con risoluzione 4K, frequenza di aggiornamento a 240Hz e tempi di risposta rapidissimi: il Gigabyte MO32U24 evolve il progetto del suo predecessore MO32U e alza ulteriormente l'asticella delle prestazioni. È ancora una volta un monitor indirizzato ai giocatori più esigenti
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
realme 16 5G è un nuovo smartphone con sensore Sony IMX 852 da 50MP sul retro e uno specchio selfie fisico integrato nella camera bar, una prima nel segmento di mercato. Batteria da 6550mAh in un corpo da 8,1mm e 183g, certificazione IP69K e ricarica da 45W completano un pacchetto aggressivo per la fascia media, per uno dei prodotti più interessanti del produttore sul piano commerciale
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Sono ormai definitive le nuove norme del Codice della Strada per i monopattini elettrici. Non solo targa e assicurazione, le regole sono tante e riguardano diversi aspetti, vi spieghiamo come evitare sanzioni che possono essere salate
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-01-2007, 13:49   #1
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
[java-mysql]non riesco ad effettuare la connessione

Come da titolo

L'ambiente su cui sto lavorando è linux (debian sid).

Il codice che sto provando è questo:

Codice:
import java.sql.*;

public class MySqlTest
{
        public static void main(String[] args) {

                Connection conn = null;

                try
                {


                        Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
                        conn = DriverManager.getConnection("jdbc:odbc://192.168.0.2:schedeauto", "raoul", "raoul");
                        System.out.println("Connessione riuscita");
                }

                catch (Exception e)
                {
                        System.err.println("Connessione non riuscita");
                }

                finally
                {
                        if (conn != null)
                        {
                                try
                                {
                                        conn.close();
                                        System.out.println("Connessione terminata");
                                }

                                catch (Exception e) {}
                        }
                }
        }
}
il driver che mi ritrovo installato è:

Codice:
dpkg -l libmysql-java

||/ Nome                         Versione                     Descrizione
+++-============================-============================-========================================================================
ii  libmysql-java                5.0.4+dfsg-2                 Java database (JDBC) driver for MySQL
In fase di compilazione non ho nessun errore;

lanciando l'applicazione ottengo invece:

"Connessione non riuscita".


Grazie

RaouL.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 17-01-2007, 14:00   #2
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Messaggi: 5206
Vedi qui: http://dev.mysql.com/doc/refman/5.0/...tes-basic.html
__________________
Andrea, Senior Java developerSCJP 5 (91%) • SCWCD 5 (94%)
Java Versions Cheat Sheet
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 17-01-2007, 14:03   #3
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Prova a sostituire la
Codice:
System.err.println("Connessione non riuscita");
Con la stampa dell'errore, cosi' hai delle info in piu'.
Codice:
System.err.println("Connessione non riuscita: " + e);
e.printStackTrace ();
(l'esempio riportera' alcune info ridondanti, ma e' meglio cosi')
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 17-01-2007, 14:27   #4
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
intanto grazie per gli aiuti

Allora, ho preso il codice dal link passatomi e l'ho adattato così:

Codice:
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

public class MySqlTest {
        public static void main (String[] args) {

                try
                {
                        Class.forName("com.mysql.jdbc.Driver").newInstance();
                        Connection conn = DriverManager.getConnection("jdbc:mysql://192.168.0.2/schedeauto?" +
            "user=raoul&password=raoul");


                }

                catch (SQLException ex) {
                    // handle any errors
                    System.out.println("SQLException: " + ex.getMessage());
                    System.out.println("SQLState: " + ex.getSQLState());
                    System.out.println("VendorError: " + ex.getErrorCode());
                }

        }
}
ma adesso quando vado a compilare questi sono gli errori che ottengo:

Codice:
javac MySqlTest.java
MySqlTest.java:10: unreported exception java.lang.ClassNotFoundException; must be caught or declared to be thrown
                        Class.forName("com.mysql.jdbc.Driver").newInstance();
                                     ^
MySqlTest.java:10: unreported exception java.lang.InstantiationException; must be caught or declared to be thrown
                        Class.forName("com.mysql.jdbc.Driver").newInstance();
                                                                          ^
2 errors


abbiate pazienza ve ne prego, con java è da qualche giorno che ho cominciato a studiare.

Grazie

RaouL.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 17-01-2007, 14:29   #5
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Messaggi: 5206
Quote:
Originariamente inviato da RaouL_BennetH
ma adesso quando vado a compilare questi sono gli errori che ottengo:

Codice:
javac MySqlTest.java
MySqlTest.java:10: unreported exception java.lang.ClassNotFoundException; must be caught or declared to be thrown
                        Class.forName("com.mysql.jdbc.Driver").newInstance();
                                     ^
MySqlTest.java:10: unreported exception java.lang.InstantiationException; must be caught or declared to be thrown
                        Class.forName("com.mysql.jdbc.Driver").newInstance();
                                                                          ^
2 errors
Devi catturare anche queste eccezioni, cioè aggiungi i catch per queste eccezioni dopo quella che hai già messo.
__________________
Andrea, Senior Java developerSCJP 5 (91%) • SCWCD 5 (94%)
Java Versions Cheat Sheet
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 17-01-2007, 14:33   #6
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Fatto anche questo e finalmente ho ricompilato senza problemi.

Quindi credo che grazie al vostro aiuto sono vicino alla soluzione del problema;

Questo è il risultato del programma:

Codice:
java MySqlTest
SQLException: No driver found for jdbc:mysql://192.168.0.2/schedeauto?user=raoul&password=raoul
SQLState: null
VendorError: 0
come faccio a capire se il driver che ho è giusto?
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 17-01-2007, 14:40   #7
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Sembrerebbe non arrivare al file .jar contenente il driver che ti interessa. Siccome lo carichi dinamicamente, puoi tranquillamente compilare ma non lo trovi in esecuzione.

Lo hai aggiunto nel CLASSPATH? Oppure lo hai copiato sotto $(Directory_di_installazione_di_Java)/jre/lib/ext ?
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 17-01-2007, 14:48   #8
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Messaggi: 5206
Quote:
Originariamente inviato da sottovento
Sembrerebbe non arrivare al file .jar contenente il driver che ti interessa. Siccome lo carichi dinamicamente, puoi tranquillamente compilare ma non lo trovi in esecuzione.
Però se non avesse trovato la classe com.mysql.jdbc.Driver, allora avrebbe dato l'eccezione ClassNotFoundException.
__________________
Andrea, Senior Java developerSCJP 5 (91%) • SCWCD 5 (94%)
Java Versions Cheat Sheet
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 17-01-2007, 15:20   #9
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
rieccomi

allora credo sia proprio un problema di driver;

un'altro esperimento di connessione con un tipo di gestione dell'errore un pochetto più preciso mi da:

Codice:
java MainTest
Errore durante la connessione.
com.mysql.jdbc.Driver not found in gnu.gcj.runtime.SystemClassLoader{urls=[file:./], parent=gnu.gcj.runtime.ExtensionClassLoader{urls=[], parent=null}}
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 17-01-2007, 15:33   #10
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Non stai quindi usando il jdk di Sun, giusto?
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 17-01-2007, 15:40   #11
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Quote:
Originariamente inviato da sottovento
Non stai quindi usando il jdk di Sun, giusto?
uhm, ho preso l'ultimo jdk dal sito sun e l'ho installato sulla macchina linux. Può darsi che debba fare ancora qualche operazione? Nel senso come faccio a capire su linux che jdk sto usando come principale?

Abbiate pazienza per le domande stupide che faccio

Grazie.

RaouL.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 17-01-2007, 15:53   #12
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Ciao,
l'errore da te pubblicato sembra riportato da un compilatore java gnu.

La mia idea e' che probabilmente hai installato il nuovo compilatore ma tu stia utilizzando ancora quello vecchio. Oppure (ancora peggio, ma mi capita sempre ) stia utilizzando il nuovo per compilare (poiche' magari hai un solo compilatore) ma un'altra virtual machine per eseguire (infatti "abbondano" se cominci ad installare applicazioni "importanti" fatte in Java, che si portano dietro la loro Virtual Machine).

Spero di non farti perdere tempo, ma il mio suggerimento e' quello di accertarti di utilizzare il giusto compilatore e la giusta Virtual Machine per eseguire: controlla la variabile d'ambiente PATH e ricorda, se trovi piu' riferimenti a virtual machine, che utilizzi la prima che viene trovata.
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 17-01-2007, 15:57   #13
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Quote:
Originariamente inviato da sottovento
Ciao,

Spero di non farti perdere tempo, ma il mio suggerimento e' quello di accertarti di utilizzare il giusto compilatore e la giusta Virtual Machine per eseguire: controlla la variabile d'ambiente PATH e ricorda, se trovi piu' riferimenti a virtual machine, che utilizzi la prima che viene trovata.
Grazie ancora per l'aiuto, ma sinceramente non so come controllare questi valori

Ho commesso l'errore di utilizzare la debian come se fossi su windows, ovvero, ho scelto di installare mediante il comodo apt (per ogni cosa che mi chiedeva in merito a java) e per li jdk mi sono limitato a lanciare l'installer scaricato dal sito sun. Confesso di non essermi preoccupato di settare alcunchè. Potreste indicarmi dove potrei controllare queste cose?

Ancora grazie.

RaouL.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 17-01-2007, 16:05   #14
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da RaouL_BennetH
Grazie ancora per l'aiuto, ma sinceramente non so come controllare questi valori

Ho commesso l'errore di utilizzare la debian come se fossi su windows, ovvero, ho scelto di installare mediante il comodo apt (per ogni cosa che mi chiedeva in merito a java) e per li jdk mi sono limitato a lanciare l'installer scaricato dal sito sun. Confesso di non essermi preoccupato di settare alcunchè. Potreste indicarmi dove potrei controllare queste cose?

Ancora grazie.

RaouL.
Scusa tu
Immagino che quindi non ha settato, nella variabile PATH, la directory che contiene compilatore & VM.

Per controllare:
echo $PATH
cosa vedi? Vedi il tuo nuovo compilatore?


Se non e' chiaro, non preoccuparti, posta ancora. Io ora vado a dormire ma ho visto che c'e' gente ben piu' preparata di me che potra' risponderti
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 17-01-2007, 16:15   #15
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
ecco, ora le cose mi sono un pò più chiare;

Tutto ciò che riguarda la nuova versione di java si trova nella mia home in:

/home/raoul/jdk1.6.0

e in questa dir ho tutte le lib, ho la dir /bin, etcetera.

Se volessi quindi settare linux in modo che quando compilo come utente raoul, utilizzo questo jdk anzichè quello nativo, cosa dovrei fare? creare un file di configurazione?

Grazie ancora !

Raoul.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 17-01-2007, 16:37   #16
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
credo di aver risolto almeno per il classpath così:

Codice:
export JAVA_HOME=/home/raoul/jdk1.6.0

export PATH=$JAVA_HOME/bin:$PATH
provo a ricompilare e vi so dire
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 17-01-2007, 16:40   #17
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Quote:
Originariamente inviato da RaouL_BennetH
credo di aver risolto almeno per il classpath così:

Codice:
export JAVA_HOME=/home/raoul/jdk1.6.0

export PATH=$JAVA_HOME/bin:$PATH
provo a ricompilare e vi so dire


come non detto!

subito dopo aver fatto l'export se faccio:

which javac e which java mi porta correttamente alla mia home, ma se compilo
il progettino mi da lo stesso errore e ripetendo il comando which mi punta di nuovo a /usr/bin/javac
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 17-01-2007, 16:46   #18
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Messaggi: 5206
Quote:
Originariamente inviato da RaouL_BennetH
Tutto ciò che riguarda la nuova versione di java si trova nella mia home in:

/home/raoul/jdk1.6.0

e in questa dir ho tutte le lib, ho la dir /bin, etcetera.

Se volessi quindi settare linux in modo che quando compilo come utente raoul, utilizzo questo jdk anzichè quello nativo, cosa dovrei fare? creare un file di configurazione?
Codice:
set PATH=/home/raoul/jdk1.6.0/bin:$PATH
Puoi lanciarlo a mano questo comando ... ma se vuoi renderlo permanente devi inserirlo in uno degli script che vengono letti all'avvio della shell, ad esempio /etc/profile (globale) oppure ad esempio .bash_profile o .profile (questi ultimi due sono "dell'utente", da mettere sotto la sua 'home').
__________________
Andrea, Senior Java developerSCJP 5 (91%) • SCWCD 5 (94%)
Java Versions Cheat Sheet
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 17-01-2007, 17:58   #19
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Quote:
Originariamente inviato da andbin
Codice:
set PATH=/home/raoul/jdk1.6.0/bin:$PATH
Puoi lanciarlo a mano questo comando ... ma se vuoi renderlo permanente devi inserirlo in uno degli script che vengono letti all'avvio della shell, ad esempio /etc/profile (globale) oppure ad esempio .bash_profile o .profile (questi ultimi due sono "dell'utente", da mettere sotto la sua 'home').
Allora, ho provato a metterlo sia in .bashrc che in .profile, ma il risultato è che poi quando mi loggo come raoul non mi riconosce nessun comando (per esempio ls, ps, etcetera... )

Ho letto la sezione sul sito Sun:

http://java.sun.com/j2se/1.4.2/docs/...classpath.html

ma se devo dire di averci capito qualcosa direi una bugia

non è che avete un .profile di esempio?

grazie

Raoul.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 17-01-2007, 18:06   #20
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Ok, adesso sembra aver memorizzato il classpath.

Provo a ricompilare e vi faccio sapere.

Grazie.

Raoul.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming Gigabyte MO32U24 OLED: il 4K a 240Hz su un panne...
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh Recensione realme 16 5G: lo smartphone con Selfi...
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni Come rispettare tutte le nuove regole per i mono...
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta DLSS 4.5: con Dynamic Frame Generation e MFG 6X ...
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Infineon apre il 2 luglio lo Smart Power...
Crimson Desert non si ferma: il gioco di...
Con iOS 27 l'iPhone si ripristina da sol...
Visa porta i pagamenti in ChatGPT: gli a...
OpenAI valuta un 'drastico' taglio dei p...
Il MacBook con display touch si far&agra...
Google promette di restituire più...
Quattro monitor 4K, doppia LAN 2.5G e Wi...
ROG Equalizer, il cavo 'salva-GPU': prim...
Falla critica CVSS 9.8 in Oracle PeopleS...
Microsoft accelera su Edge: aggiornament...
AMD ha corretto un bug da 10.000 dollari...
Vertiv: data center, la corsa dell’IA sp...
Siri non diventerà la tua fidanzata virt...
Prezzi in crescita del 200% e forniture ...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 23:48.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v