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

Langage Java Discussion :

classe dans un meme package mais inconnu


Sujet :

Langage Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé

    Profil pro
    MOA
    Inscrit en
    Décembre 2002
    Messages
    1 244
    Détails du profil
    Informations personnelles :
    Localisation : France, Eure et Loir (Centre)

    Informations professionnelles :
    Activité : MOA

    Informations forums :
    Inscription : Décembre 2002
    Messages : 1 244
    Par défaut classe dans un meme package mais inconnu
    Bonjour,


    Je me suis créé une classe, MaConnexion, qui me permettra de gerer ma connexion à la base de donnée.

    Dans le fichier main, je me suis créé une instance de ma classe MaConnexion l'affectant à la variable maSQL :
    MaConnexion maSQL = new MaConnexion();

    puis je veux appeller la méthode insert2(). Utilisateur de netbean6, j'ecris donc ma variable maSQL puis le . et apres je fais Alt+Espace pour choisir ma méthode insert2();

    Je ne comprends absolument pas pourquoi Netbean m'indique que le package maSQL n'existe pas. Comme vous pouvez le voire sur le screen, la classe MaConnexion et Main sont dans le meme package gestionemploi2. Dans le fichier Main et Maconexion, j'ai preciser : package gestionemploi2;





    Ma classe :
    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
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
     
     package gestionemploi2;
     
    import java.sql.*;
    import java.util.logging.Level;
    import java.util.logging.Logger;
     
     
    public class MaConnexion {
     
        private Connection myConnection;
     
        public MaConnexion() {
            try {
                Class.forName("com.mysql.jdbc.Driver");
                myConnection=DriverManager.getConnection("jdbc:mysql://localhost/java","root", "");
            } catch (SQLException ex) {
                Logger.getLogger(MaConnexion.class.getName()).log(Level.SEVERE, null, ex);
            } catch (ClassNotFoundException ex) {
                Logger.getLogger(MaConnexion.class.getName()).log(Level.SEVERE, null, ex);
            }
        }
        public void Insert2 () {
            String q = "INSERT INTO `entreprise` ( `ENTREPRISE_ID` , `NOM` ) VALUES ('', 'coucouc');";
     
            try {
                Statement stmt = myConnection.createStatement();
                 stmt.executeUpdate(q);
            } catch (SQLException ex) {
                Logger.getLogger(MaConnexion.class.getName()).log(Level.SEVERE, null, ex);
            }
     
        }   
    }
    et mon fichier main :



    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
     
    package gestionemploi2;
     
    public class Main {
     
        MaConnexion maSQL = new MaConnexion();
        maSQL.insert2();
     
    }

  2. #2
    Expert éminent
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Billets dans le blog
    1
    Par défaut
    Salut,


    Insert2 n'est pas la même chose que insert2...


    Quand à ta classe MyConnexion elle a un gros problème : aucune ressource n'est jamais libérer !

    Comment libérer proprement les ressources ?

    a++

  3. #3
    Membre éprouvé

    Profil pro
    MOA
    Inscrit en
    Décembre 2002
    Messages
    1 244
    Détails du profil
    Informations personnelles :
    Localisation : France, Eure et Loir (Centre)

    Informations professionnelles :
    Activité : MOA

    Informations forums :
    Inscription : Décembre 2002
    Messages : 1 244
    Par défaut
    Citation Envoyé par adiGuba Voir le message
    Salut,


    Insert2 n'est pas la même chose que insert2...


    Quand à ta classe MyConnexion elle a un gros problème : aucune ressource n'est jamais libérer !

    Comment libérer proprement les ressources ?

    a++
    Et bien curieusement, comme je l'ai dit, c'est Netbean qui m'a rajouter le nom de la méthode (Alt + Espace). Ils s'est donc trompé en mettant un i minuscule. Bizzare.


    Pour la libération des ressources. N'est ce pas suffisant de créer une méthode close.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     private Connection myConnection;
     
     public void Close () {
            try {
                myConnection.close();
            } catch (SQLException ex) {
                Logger.getLogger(MaConnexion.class.getName()).log(Level.SEVERE, null, ex);
            }
    Mais dans ce cas, il faudrait que cette méthode soit dans un bloc finally pour être sur à 100% qu'elle va s'exécuter même en cas d'exception.

    Seul souci, la portée des variables. Elles sont limitées à l'interieur d'un bloc. Il font donc penser à creer sa variable maSQL en dehors du catch.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
             MaConnexion maSQL = new MaConnexion();
             try {
                maSQL.Insert("INSERT INTO `entreprise` ( `ENTREPRISE_ID` , `NOM` ) VALUES ('', 'c moi');");
             }
             finally {
                maSQL.Close();
            }
    Corrige moi si je me trompe. Sinon un grand merci à toi.

  4. #4
    Expert éminent
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par weed Voir le message
    Pour la libération des ressources. N'est ce pas suffisant de créer une méthode close.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     private Connection myConnection;
     
     public void Close () {
            try {
                myConnection.close();
            } catch (SQLException ex) {
                Logger.getLogger(MaConnexion.class.getName()).log(Level.SEVERE, null, ex);
            }
    Oui... mais ici tu ne fermes que la Connexion et il vaut mieux fermer également les Statement/ResultSet, par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    	public void Insert2() {
    		String q = "INSERT INTO `entreprise` ( `ENTREPRISE_ID` , `NOM` ) VALUES ('', 'coucouc');";
     
    		try {
    			Statement stmt = myConnection.createStatement();
    			try {
    				stmt.executeUpdate(q);
    			} finally {
    				stmt.close();
    			}
    		} catch (SQLException ex) {
    			Logger.getLogger(MaConnexion.class.getName()).log(Level.SEVERE,null, ex);
    		}
    	}
    C'est d'autant plus vrai lorsque tu réutilises la même connexion pendant un certain temps (et que tu crées plusieurs Statement sans les fermer...)


    Citation Envoyé par weed Voir le message
    Mais dans ce cas, il faudrait que cette méthode soit dans un bloc finally pour être sur à 100% qu'elle va s'exécuter même en cas d'exception.
    Oui tout à fait !

    Et si tu es parano tu peux aussi redéfinir finalize() pour (re)forcer le close().




    Citation Envoyé par weed Voir le message
    Seul souci, la portée des variables. Elles sont limitées à l'interieur d'un bloc. Il font donc penser à creer sa variable maSQL en dehors du catch.
    Oui tout à fait.



    Sinon juste un détail : les nom de variables et de méthodes commencent par une minuscule en Java

    a++

Discussions similaires

  1. [DEBUTANT] Ouvrir une classe qui est dans le meme package
    Par quake3 dans le forum Débuter avec Java
    Réponses: 3
    Dernier message: 22/09/2009, 14h03
  2. héritage d'une classe pas dans le meme package
    Par marry dans le forum Général Java
    Réponses: 14
    Dernier message: 07/05/2009, 18h14
  3. Réponses: 2
    Dernier message: 05/10/2007, 10h04
  4. Réponses: 8
    Dernier message: 23/11/2006, 11h30
  5. Comment Accéder au une classe d'un meme package
    Par CrazySeb dans le forum Langage
    Réponses: 2
    Dernier message: 28/04/2006, 22h43

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