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

Composants Java Discussion :

java FormattedTextField en jdbc


Sujet :

Composants Java

  1. #1
    Membre habitué Avatar de Hind4Dev
    Femme Profil pro
    Administrateur de base de données
    Inscrit en
    Novembre 2014
    Messages
    428
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2014
    Messages : 428
    Points : 140
    Points
    140
    Par défaut java FormattedTextField en jdbc
    Bonjour,

    J'ai un problème lors de l'insertion du contenu d'un FormattedTextField, la fonction d'insertion fonctionne sauf le champ du mask il ne s'enregistre pas:
    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
    publicvoid insertInfo()throwsException{
        try{
            int codeNat = getNat();
    
            String query ="INSERT INTO info (id,name,code_nat) VALUES (?,?,?)";
    
            stat = cnx.prepareStatement(query);
            stat.setString(1, txtId.getText());
            stat.setString(2, txtName.getText());//masked formatted field
            stat.setInt(3, codeNat);
    
            stat.execute();
            Update_table();
    
        }catch(SQLException ex){
            JOptionPane.showMessageDialog(null,ex);
        }
        finally{
                stat.close();
        }
    }
    voilà la déclaration :

    JFormattedTextField txtName =newJFormattedTextField();
    mask
    =newMaskFormatter("########/##");
    mask
    .install(txtName);

    la compilation ne génère aucune exception seulement le champs reste vide

  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,

    Crée le champ comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    MaskFormatter mask= new MaskFormatter("########/##");
    JFormattedTextField txtName =new JFormattedTextField(mask);
    mask.install(txtName);
    Et récupère la saisie par :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (String)txtName.getValue()
    Attention, cette valeur peut être null si la saisie n'est pas conforme au masque, ou l'ancienne valeur affectée au champ (voir aussi JFormattedTextField.setFocusLostBehavior()):

    Tu peux valider si la saisie est conforme en invoquant explicitement txtName.commitEdit();.
    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 habitué Avatar de Hind4Dev
    Femme Profil pro
    Administrateur de base de données
    Inscrit en
    Novembre 2014
    Messages
    428
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2014
    Messages : 428
    Points : 140
    Points
    140
    Par défaut
    j'ai mis ce code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    stat.setString(2, (String)txtName.getValue());
    mais voilà ce que ça donne:

    Nom : bb.jpg
Affichages : 91
Taille : 60,0 Ko

  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
    Je peux voir le nouveau code complet ?
    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 habitué Avatar de Hind4Dev
    Femme Profil pro
    Administrateur de base de données
    Inscrit en
    Novembre 2014
    Messages
    428
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2014
    Messages : 428
    Points : 140
    Points
    140
    Par défaut
    voici la fonction:
    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
     
    public void insertInfo() throws Exception{
            try{
                int codeNat = getNat();
     
                String query = "INSERT INTO info (id,name,code_nat) VALUES (?,?,?)";
     
     
                stat = cnx.prepareStatement(query);
                stat.setString(1, txtId.getText());
                stat.setString(2, (String)txtName.getValue());
                stat.setInt(3, codeNat);
     
                stat.execute();
                Update_table();
     
     
            }catch(SQLException ex){
                JOptionPane.showMessageDialog(null,ex);
            }
            finally{
                    stat.close();
            }
        }
    et la définition:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    MaskFormatter mask ;
    JFormattedTextField txtName = new JFormattedTextField(mask);
     
    // un peu plus loin:
    txtName = new JFormattedTextField(mask);
            mask = new MaskFormatter("########/##");
            mask.setPlaceholderCharacter('_');
            mask.install(txtName);

  6. #6
    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
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    MaskFormatter mask ;
    JFormattedTextField txtName = new JFormattedTextField(mask);
     
    // un peu plus loin:
    txtName = new JFormattedTextField(mask);
            mask = new MaskFormatter("########/##");
            mask.setPlaceholderCharacter('_');
            mask.install(txtName);
    Bah, oui, tu passes null en paramètre du constructeur du JFormattedTextField. Il faut affecter la variable mask avec l'instance du MaskFormatter avant d'instancier le JFormattedTextField.

    Et inutile de l'instancier une première vois dans la déclaration, dont je suppose qu'elle n'est pas dans la méthode, sinon, tu pourrais pas compiler. D'ailleurs si avoir txtName dans le scope de la classe peut avoir une utilité, je n'en vois aucune pour mask.
    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.

  7. #7
    Membre habitué Avatar de Hind4Dev
    Femme Profil pro
    Administrateur de base de données
    Inscrit en
    Novembre 2014
    Messages
    428
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2014
    Messages : 428
    Points : 140
    Points
    140
    Par défaut
    Ahaaa!! j'ai compris c'est bon ça fonctionne à merveille, merci bien

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

Discussions similaires

  1. Java linux driver JDBC
    Par Gillouz dans le forum JDBC
    Réponses: 7
    Dernier message: 28/11/2008, 21h28
  2. [JDBC] java.sql.SQLException: Closed Statement
    Par cmoulin dans le forum JDBC
    Réponses: 4
    Dernier message: 03/09/2004, 17h22
  3. [JDBC] manipulation des dates/heures en Java
    Par kurkLord dans le forum JDBC
    Réponses: 6
    Dernier message: 09/08/2004, 12h49
  4. [JDBC] Programmation autre que Java
    Par Vow dans le forum JDBC
    Réponses: 2
    Dernier message: 23/06/2004, 11h22
  5. [JDBC]java - mysql : Pb de driver
    Par xiao-long974 dans le forum JDBC
    Réponses: 2
    Dernier message: 03/06/2004, 09h19

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