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

Persistance des données Java Discussion :

Procédure stockée avec le modèle DAO


Sujet :

Persistance des données Java

  1. #1
    Membre averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2014
    Messages
    352
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Octobre 2014
    Messages : 352
    Points : 349
    Points
    349
    Par défaut Procédure stockée avec le modèle DAO
    Bonsoir à tous,

    J'ai bien réussi la partie le modèle DAO du tutoriel "créez votre application web avec java ee".

    Maintenant, je voudrais le faire avec des procédure stockées dont j'ai vérifié le bon fonctionnement dans mysql server. Le problème, dans le code, est que je n'arrive pas à faire fonctionner la procédure d'insertion, alors que celle qui fait la sélection de tous les clients fonctionne bien.

    Voici comment je structure le code de ClientDaoImpl :

    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
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    package DAO;
     
    import static DAO.DAOUtilitaire.fermeturesSilencieuses;
    import static DAO.DAOUtilitaire.initialisationRequetePreparee;
     
    import java.sql.Connection;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.util.ArrayList;
    import java.util.List;
     
     
    import DAO.Client;
     
     
     
    public class ClientDaoImpl implements ClientDao{
        private static final String selection = "call selectionClient()";
     
        private static final String selectionParIdentifiant = "select * from client where id = ?";
     
        private static final String insertion = "call AjoutClient('nomC','prenomC','adresseC','emailC','telephoneC')";
     
        private static final String suppression = "delete from client where id = ?";
     
        private DAOFactory          daoFactory;
     
         ClientDaoImpl(DAOFactory daoFactory) {
        this.daoFactory =     daoFactory;
     }
     
        public Client selection(Long id) throws DAOException {
            return selection(selectionParIdentifiant,id);
        }
     
        public Client selection(String requete, Object... objets) throws DAOException {
        Connection connection = null;
        PreparedStatement preparedStatement = null;
        ResultSet resulta = null;
        Client client = null;
        try{
            connection = daoFactory.getConntion();
            preparedStatement = initialisationRequetePreparee(connection,requete,false,objets);
            resulta = preparedStatement.executeQuery();
            while(resulta.next()){
                client = clientDansBeans(resulta);
            }
        }catch(SQLException e){
            throw new DAOException("La selection a échoué.",e);
        }finally {
            fermeturesSilencieuses( resulta, preparedStatement,connection );
        }
        return client;
        }
     
        public void ajout(Client ajouter) throws DAOException {
       Connection connection = null;    
       PreparedStatement preparedStatement = null;
     
       try{
           connection = daoFactory.getConntion();
           preparedStatement = connection.prepareStatement(insertion);
     
           int conf = preparedStatement.executeUpdate();
           if(conf == 0){
               throw new DAOException("Echec de l'enregistrement.");
           }
              }catch( SQLException e){
           throw new DAOException(e);
           }finally{
               fermeturesSilencieuses(preparedStatement,connection);
           }
        }
     
     
        public void supprimer(Client supClient) throws DAOException {
           Connection connexion = null;
           PreparedStatement preparedStatement = null;
           try{
               connexion = daoFactory.getConntion();
               preparedStatement = initialisationRequetePreparee(connexion,suppression,true,supClient.getId());
               int resultaSup =  preparedStatement.executeUpdate();
           if(resultaSup == 0){
     
               throw new DAOException("Echec de suppression.Merci de reessayer!!!");
           }
           else{
               supClient.setId(null);
           }
           }catch(SQLException e){
               throw new DAOException(e);
           } finally {
               fermeturesSilencieuses( preparedStatement, connexion );
           }
        }
     
        @Override
        public List<Client> listerClient() throws DAOException {
            Connection connection = null;
            PreparedStatement preparedStatement = null;
            ResultSet resulta = null;
            List<Client> clients = new ArrayList<Client>();
            try {
            connection = daoFactory.getConntion();
            preparedStatement = connection.prepareStatement(selection);
            resulta = preparedStatement.executeQuery();
            while ( resulta.next() ) {
            clients.add(clientDansBeans( resulta ) );
            }
            } catch ( SQLException e ) {
               throw new DAOException( e );
            } finally {
            fermeturesSilencieuses( resulta, preparedStatement,connection );
            }
            return clients;
        }
        private static Client clientDansBeans(ResultSet resulta) throws SQLException {
             Client client = new Client();
             client.setId(resulta.getLong("id"));
             client.setNom(resulta.getString("nom"));
             client.setPrenom(resulta.getString("prenom"));
             client.setAdresse(resulta.getString("adresse"));
             client.setEmail(resulta.getString("email"));
             client.setTelephone(resulta.getString("telephone"));
     
             return client;
            }
    }
    Ça insère dans la base de données nomC;prenomC;adresseC;emailC;telephoneC alors que mon but est de récupérer des données saisies depuis le formulaire et les insérer dans la base de données en les passant en paramètres de ma procédure. Je ne vois vraiment pas comment m'y prendre.

    Merci d'avance pour votre aide.

  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,

    Dans la requête d'un preparedStatement, on représente les paramètres par des ?, comme tu as fait pour "select * from client where id = ?", donc au lieu de "call AjoutClient('nomC','prenomC','adresseC','emailC','telephoneC')", il faudrait "call AjoutClient(?,?,?,?,?)"

    Ensuite, il faut affecter à chacun de ces paramètres les bonnes valeurs depuis tes instances de classe dans cette séquence :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    connection = daoFactory.getConntion();
    preparedStatement = connection.prepareStatement(insertion);
     
    // ici on affecte les paramètres
    preparedStatement.setString( 1, ajouter.getNom() );
    preparedStatement.setString( 2, ajouter.getPrenom() );
    // pareil avec adresse, email et telephone.
     
    int conf = preparedStatement.executeUpdate();
    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 averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2014
    Messages
    352
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Octobre 2014
    Messages : 352
    Points : 349
    Points
    349
    Par défaut Procédure stockée avec le modèle DAO
    Merci joel,Tout marche comme souhaité mais que voulez vous par : instances de classe dans cette sequence?

  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'expliquais juste qu'il faut appeler les méthodes du type preparedStatement.setString(numéro de colonne,...) avec les bonnes valeurs, pour passer les 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.

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 10/03/2015, 04h11
  2. Procédure stockée avec SELECT UNION
    Par maredami dans le forum Oracle
    Réponses: 4
    Dernier message: 07/11/2005, 11h05
  3. Procédure stockée avec serveur lié et paramètres
    Par AITOZ dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 27/10/2005, 17h51
  4. Procédure stockée avec param de sortie:marchepas av ADO
    Par Fabby69 dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 14/10/2004, 12h04

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