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 :

Problème de connexion JDBC


Sujet :

JDBC Java

  1. #1
    Nouveau membre du Club
    Inscrit en
    Mai 2010
    Messages
    51
    Détails du profil
    Informations forums :
    Inscription : Mai 2010
    Messages : 51
    Points : 28
    Points
    28
    Par défaut Problème de connexion JDBC
    * Bonjour, *

    je suis débutante avec java (netbeans).
    je veux créer une classe pour se connecter à une base de donnée mysql
    mais lorsque j'ai mis ce code dans mon programme, il est devenu tout souligné rouge.
    j'ai essayé toute les propositions pour le corriger mais en vain.
    veulliez m'aider svp
    voila le bout de 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 connect_db {
     
               try {
                    Class.forName("com.mysql.jdbc.Driver").newInstance();
                    }catch(Exception e) {
                     System.err.println("Exception: " + e.getMessage());
                    }
               try {     
                    Connection con = DriverManager.getConnection("jdbc:derby://localhost:1527/clt_mbl [root on ROOT]","root","admin");
                   } catch (ClassNotFoundException cE) {
                    System.out.println("Class Not Found Exception: "+ cE.toString());
            }
              }
    merci d'avance

  2. #2
    Membre régulier

    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2011
    Messages
    37
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2011
    Messages : 37
    Points : 81
    Points
    81
    Par défaut
    Bonsoir,

    Pour créer une classe de connexion, il faut que tu instancies un ou des constructeurs de ta classe connect_db.

    Pour cela tu dois définir des propriétés tel que le protocole, le serveur, la base, l'utilisateur, le mot de passe et le driver. Ensuite tu instancies tes constructeurs selon tes besoins.

    Voici un 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
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    import java.sql.*;
     
    public class Connexion 
    {
    	private String protocole="jdbc:mysql";
    	private String serveur="localhost";
    	private String base="nomdetabase";
    	private String utilisateur="root";
    	private String motdepasse="";
    	private String dbDriver="com.mysql.jdbc.Driver";
     
    	private int res = 0;
    	private int lastInsertId=-1;
     
    	private Connection dbCon;
     
    	public Connexion()
    	{
    	}
    	public Connexion(String base,String utilisateur,String motdepasse)
    	{
    		this.base=base;
    		this.utilisateur=utilisateur;
    		this.motdepasse=motdepasse;
    	}
    	public Connexion(String dbDriver,String protocole,String serveur,String base,String utilisateur,String motdepasse)
    	{
    		this(base,utilisateur,motdepasse);
    		this.dbDriver=dbDriver;
    		this.protocole=protocole;
    		this.serveur=serveur;
    	}
    Ensuite, il va falloir que tu écrives des méthodes te permettant de te connecter à ta base de données et de fermer la connection

    Voici un 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
    15
    16
    public void connect() throws ClassNotFoundException,SQLException
    	{
     
    		String dbURL=protocole + "://" + serveur + "/" + base + "?user=" + utilisateur + "&" + "password=" + motdepasse;
    		// import dynamique du driver de base de données
    		Class.forName(dbDriver);
    		dbCon = DriverManager.getConnection(dbURL);
    		/* si le driver n'a pas été trouvé (ClassNotFoundException)
    		 * ou si la connexion a été refusée (SQLException), 
    		une exception est levée*/
    	}
     
    	public void close() throws SQLException
    	{ 
    		dbCon.close();
    	}
    Et enfin, il te faut des méthodes te permettant de dialoguer avec ta base de données, ceci afin de pouvoir effectuer des insert, des delete, des update et des select

    Voici un 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
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    public ResultSet select(String sql) throws SQLException
    	{ 
    		Statement s = dbCon.createStatement();
    		ResultSet r = s.executeQuery(sql);
    		return r;
    	}
     
    	public int insert(String sql) throws SQLException
    	{
    		return (execDDL(sql,Statement.RETURN_GENERATED_KEYS));
    	}
     
    	public int update(String sql) throws SQLException
    	{
    		return (execDDL(sql,Statement.NO_GENERATED_KEYS));
    	}
     
    	public int delete(String sql) throws SQLException
    	{
    		return (execDDL(sql,Statement.NO_GENERATED_KEYS));
    	}
     
    	/* la méthode de base servant à exécuter les insert,delete,update est la même
    	* le paramètre flag sert à indiquer qu'en cas d'insert , 
    	* on stockera  l'id de l'enregistrement inséré dans l'attribut lastInsertId
    	 */
    	private int execDDL(String sql,int flag) throws SQLException
    	{
    		Statement stmnt = dbCon.createStatement();
    		res = stmnt.executeUpdate(sql,flag);
     
    		if (flag==Statement.RETURN_GENERATED_KEYS)
    		{
    			ResultSet rs = stmnt.getGeneratedKeys();
    			while(rs.next())	this.lastInsertId = rs.getInt(1);
    			rs.close();
    		}
     
    		return res;	
    	}
    	public int getLastInsertId()
    	{
    		return lastInsertId;
    	}
    Tout ceci mis bout à bout te donne ta classe de connexion. Elle te permettra d'instancier des objets Connexion dans d'autres classes afin de dialoguer avec la base de données.

    Toutefois n'oublies pas d'insérer dans ton projet le mysql-connector.jar

    N'hésite pas si tu as d'autres questions
    Mon entreprise recrute des développeurs C#, n'hésitez pas à me contacter par MP

  3. #3
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Citation Envoyé par b_imen Voir le message
    mais lorsque j'ai mis ce code dans mon programme, il est devenu tout souligné rouge.
    C'est parce que ce sont des instructions, et les instructions doivent se trouver dans un bloc de code. Les bloc de code sont dans les méthode et les constructeur. En dehors, on peux juste déclarer des champs, des méthodes et des constructeurs.

    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
       public class ConnectDb { 
          // merci de suivre les convention java pour 
          // nommer vos classes au passage ;)
          Connection connection;
          public ConnectDb(){  
              try {
                    Class.forName("com.mysql.jdbc.Driver").newInstance();
              }catch(ClassNotFoundException  e) {
                    // ne JAMAIS faire un catch(Exception) c'est trop généraliste
                    System.err.println("Exception: " + e.getMessage());
                    e.printStackTrace(); 
                    // toujours afficher la stacktrace, en général 
                    // le message est inutile pour le développeur
              }
              try {     
                    Connection con = DriverManager.getConnection("jdbc:derby://localhost:1527/clt_mbl [root on ROOT]","root","admin");
              } catch (SQLException cE) { 
                    // Qu'est-ce qu'il foutait là le ClassNotFoundException?
                    cE.printStackTrace();
     
              }
          }
          /**
           * accès à la connection
           */
          public Connection getConnection(){
              return connection;   
          }  
    }

  4. #4
    En attente de confirmation mail
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Octobre 2010
    Messages
    501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Octobre 2010
    Messages : 501
    Points : 1 060
    Points
    1 060
    Par défaut
    Citation Envoyé par tchize_ Voir le message
    Les bloc de code sont dans les méthode et les constructeur. En dehors, on peux juste déclarer des champs, des méthodes et des constructeurs.
    On peut aussi mettre du code dans un bloc static { (...) } dans une classe.
    Typiquement, un Class.forName pourrait bien figurer dans ce genre de bloc.

  5. #5
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Citation Envoyé par Nudger Voir le message
    On peut aussi mettre du code dans un bloc static { (...) } dans une classe.
    Typiquement, un Class.forName pourrait bien figurer dans ce genre de bloc.
    j'ai évité d'énumérer les cas spéciaux, vu que c'est un débutant

  6. #6
    Nouveau membre du Club
    Inscrit en
    Mai 2010
    Messages
    51
    Détails du profil
    Informations forums :
    Inscription : Mai 2010
    Messages : 51
    Points : 28
    Points
    28
    Par défaut
    je vous remercie infiniment les pro pour vos réponses assez claires et détaillées..

  7. #7
    Nouveau membre du Club
    Inscrit en
    Mai 2010
    Messages
    51
    Détails du profil
    Informations forums :
    Inscription : Mai 2010
    Messages : 51
    Points : 28
    Points
    28
    Par défaut
    Bonjour,

    j'ai crée une table avec un champ id pour compter le nombre de client,
    comment faire pour que ce champ s'incrémente automatiquement suite à l'ajout d'un client vue qu'il n'est pas la clé primaire de ma table

    Merci

Discussions similaires

  1. Problème de connexion JDBC SQLServer
    Par Iloyo dans le forum MS SQL Server
    Réponses: 0
    Dernier message: 06/01/2012, 15h13
  2. problème de Connexion JDBC
    Par sebac dans le forum JDBC
    Réponses: 1
    Dernier message: 05/08/2009, 16h30
  3. Problème de connexion JDBC MySQL
    Par FabaCoeur dans le forum JDBC
    Réponses: 5
    Dernier message: 08/03/2008, 11h06
  4. Problème de connexion JDBC
    Par skyangel dans le forum JDBC
    Réponses: 1
    Dernier message: 28/11/2007, 20h48
  5. [Tomcat, Postgresql & JSP] Problème de connexion JDBC
    Par quichedood dans le forum Tomcat et TomEE
    Réponses: 3
    Dernier message: 14/03/2006, 13h27

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