IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

JDBC Java Discussion :

Erreur "cannot find symbol"


Sujet :

JDBC Java

  1. #1
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2012
    Messages
    63
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2012
    Messages : 63
    Points : 42
    Points
    42
    Par défaut Erreur "cannot find symbol"
    Bonjour à tous,

    j'ai pour objectif de lier une application java à une BDD Oracle. J'arrive à connecter mon application dans les services de Netbean, mais une fois que je fais la connexion dans le code, j'ai des erreur de type : cannot find symbol symbol : class sql au niveau de la ligne 7 après le "="

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    public class WebService {
     
        public static void main (String[] args)
        {
            try{
                Class.forName("oracle.jdbc.driver.OracleDriver");
                java.sql.Connection connection = java.sql.DriverManager;
                DriveManager.getConnection("jdbc:oracle:thin:@localhost:1521:XE", "oracle.jdbc.OracleDriver", "SYSTEM", "chrozak");    
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
    J'aimerais savoir comment régler ce problème qui me bloque.

    Merci d'avance à vous .

  2. #2
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Salut,

    Je t'ai mis en rouge les caractères que tu dois supprimer dans ton code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    public class WebService {
    
        public static void main (String[] args)
        {
            try{
                Class.forName("oracle.jdbc.driver.OracleDriver");
                java.sql.Connection connection = java.sql.DriverManager;
                DriveManager.getConnection("jdbc:oracle:thin:@localhost:1521:XE", "oracle.jdbc.OracleDriver", "SYSTEM", "chrozak");    
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }


    Dans ton code, la ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    java.sql.Connection connection =  java.sql.DriverManager;
    Je suppose que tu as ajouté ça lorsque tu as eu une erreur signalé sur la ligne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
                DriveManager.getConnection("jdbc:oracle:thin:@localhost:1521:XE", "oracle.jdbc.OracleDriver", "SYSTEM", "chrozak");
    ou il manque juste le premier r de DriverManager (aussi faut il ajouter l'import, import java.sql.DriverManager;, si ça n'est pas déjà fait).


    veut dire que tu essayes de mettre une valeur dans connection et que cette valeur est java.sql.DriverManager qui le nom d'une classe qui n'est absolument pas une instance de Connection (la seule valeur qu'on puisse mettre dans la variable connection.

    Le code final correct :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    public class WebService {
     
        public static void main (String[] args)
        {
            try{
                Class.forName("oracle.jdbc.driver.OracleDriver");
                java.sql.Connection connection = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:XE", "oracle.jdbc.OracleDriver", "SYSTEM", "chrozak");    
     
                ... ici tu peux utiliser connection pour le manipuler
     
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
    Par ailleurs, au lieu de catcher Exception, tu devrais catcher chaque exception séparément pour les traiter plus finement. Autant le ClassNotFoundException qu'on peut obtenir sur l'appel de Class.forName ne peut arriver qu'au développement ou après une installation incorrecte (manquerait le jar du driver), et donc peut se traiter complètement à part. Autant les erreurs de connexions à une base peuvent avoir différentes circonstances, d'installation ou d'exploitation (ne serait ce que la base n'est pas démarrée, ou qu'un firewall bloque le port 1521... ou que le schéma est incorrect et que le user n'existe pas, etc...)
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  3. #3
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2012
    Messages
    63
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2012
    Messages : 63
    Points : 42
    Points
    42
    Par défaut
    J'ai changé mon code comme tu me l'a dis, mais j'ai cette erreur maintenant

    "no suitable method found for getConnection(String,String,String,String)
    method DriverManager.getConnection(String,Properties) is not applicable
    (actual and formal argument lists differ in length)
    method DriverManager.getConnection(String,String,String) is not applicable
    (actual and formal argument lists differ in length)
    method DriverManager.getConnection(String) is not applicable
    (actual and formal argument lists differ in length)
    method DriverManager.getConnection(String,Properties,Class<?>) is not applicable
    (actual and formal argument lists differ in length)"

    Sinon tu n'aurais pas un tuto qui marche que je puisse le suivre ou il expliquerait comment effectuer la connexion ?

  4. #4
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    J'avais pas fait attention que tu passais 4 paramètres à getConnection(). Supprilme le second paramètre : les paramètres étant url, user et password (3 paramètres).
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  5. #5
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2012
    Messages
    63
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2012
    Messages : 63
    Points : 42
    Points
    42
    Par défaut
    Merci !!! je n'ai plus d'erreur au niveau de ma connexion, ça fais plaisir .

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 0
    Dernier message: 16/03/2012, 20h59
  2. Erreur : cannot find symbol d'une metode de java.lang.Object
    Par strokeswan1 dans le forum API standards et tierces
    Réponses: 1
    Dernier message: 16/05/2011, 08h44
  3. Erreur "cannot find symbol"
    Par popy67 dans le forum Débuter avec Java
    Réponses: 3
    Dernier message: 03/01/2011, 15h25
  4. erreur cannot find symbole
    Par ekahrd dans le forum Débuter avec Java
    Réponses: 1
    Dernier message: 10/05/2009, 16h42

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo