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 :

[debutant] jdbc


Sujet :

JDBC Java

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Février 2005
    Messages
    54
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 54
    Points : 31
    Points
    31
    Par défaut [debutant] jdbc
    Bonjour à tous,

    voila j'ai un petit probleme, j'ai une table dans ma bd ou je veux inserrer toutes les requete effectué sur autres tables mais
    les caracteres ' et " dans les requetes à inserrer me font des conflit avec ceux de la requete de l'insertion c'est koi la sollution

    ex:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    marequete = insert into table values('xxxx')
    insert into matable values ('marequete')
    j'ai essayer avec la methode marequete.replace (char, char)
    mais replace ne veux pas accepter ' et " comme param

    merci pour votre aide.

  2. #2
    Membre éclairé Avatar de remika
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    806
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 806
    Points : 861
    Points
    861
    Par défaut
    il faut faire des PreparedStatement avec des setString au lieu des Statement

    ou moins propre tu utilises replaceAll au lieu de replace
    Ignorer c'est aussi croire que l'on sait.
    Merci d'essayer d'écrire correctement.
    Pas de questions techniques par MP SVP.

  3. #3
    Expert éminent sénior
    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
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Salut,


    Regarde du coté des prepared statement...

    a++

    [edit] grillé

  4. #4
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Février 2005
    Messages
    54
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 54
    Points : 31
    Points
    31
    Par défaut
    c'est que j'ai essayé de faire mais ça passe 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
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    public void addQuery(String arg){
            Connection conn = null;
            Statement stmt = null;
            int res = 0;
     
            arg.replaceAll("'","~");
     
            String query="insert into sqlinstructions (sqlinstruction,tsa) values ('"+arg+"',current timestamp)";
     
            System.out.println(query);
            try {
    			conn = init();
    			stmt = conn.createStatement();
    			res =
    				stmt.executeUpdate(query);
     
    		} catch (SQLException e) {
    			System.out.println("ajout de requette echoué");
    			e.printStackTrace();
    		} catch (ClassNotFoundException cnf) {
    			System.out.println("La classe du driver jdbc n'a pu etre charge");
    			cnf.printStackTrace();
    		} finally {
    			if (stmt != null)
    				try {
    					stmt.close();
    					conn.close();
    				} catch (SQLException e) {
    				}
    		}
    		if (res < 0) {
    		    System.out.println("ajout de requette impossible");
    		} else {
    		    System.out.println("ajout de requette reussi");
    		}
        }

  5. #5
    Membre éclairé Avatar de remika
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    806
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 806
    Points : 861
    Points
    861
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    PreparedStatement stmt =null;
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    String query="insert into sqlinstructions (sqlinstruction,tsa) values (?,current timestamp)";
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    stmt = conn.prepareStatement(query);
    stmt .setString(1,arg);
    res =stmt.executeUpdate();
    Ignorer c'est aussi croire que l'on sait.
    Merci d'essayer d'écrire correctement.
    Pas de questions techniques par MP SVP.

  6. #6
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Février 2005
    Messages
    54
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 54
    Points : 31
    Points
    31
    Par défaut
    yes all right
    ça marche merci beaucoup

    je peux me permettre de faire Résolu alors

  7. #7
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Février 2005
    Messages
    54
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 54
    Points : 31
    Points
    31
    Par défaut
    Re Bonjour tous le monde,
    puisque je me suis rendu compte que les caracteres ' et " posent des probleme dans tout les champs texte que j'ai changé les statement par des preparestatement dans les autres classes mais le probleme que ma methode
    public void addQuery(String arg) (au dessus) me prend plus les params du prepare statement
    je voie plus comment faire

    voila le code de l'ajout de contact
    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
    public int addContact(Contacts contact) {
     
            Connection conn = null;
            PreparedStatement stmt = null;
            int rs = 0;
            int idcontact = new DriverJDBC().setId("Contacts", "idcontact");
            String query = "INSERT INTO Contacts (Resellerid,ContactTypeid,Surname,Name"
            + ",Phone,CellPhone,Fax,Email,Compicheid,title,idcontact,positions,LastUpdate,TSA) VALUES(?,?,?,?,?,?,?,?,?,?,?,?,current timestamp,current timestamp)";
     
            try {
     
                conn = init();
                stmt = conn.prepareStatement(query);
     
                stmt.setInt(1,contact.getIdReseller());
                stmt.setInt(2,contact.getIdContacType());
                stmt.setString(3, contact.getSurname());
                stmt.setString(4, contact.getName());
                stmt.setString(5, contact.getPhone());
                stmt.setString(6, contact.getCellPhone());
                stmt.setString(7, contact.getFax());
                stmt.setString(8, contact.getEmail());
                stmt.setInt(9,new UserController().GetUser().getIdCompiche());
                stmt.setString(10, contact.getTitle());
                stmt.setInt(11,idcontact);
                stmt.setString(12,contact.getPosition());
     
                rs = stmt.executeUpdate();
     
                stmt.close();
     
     
     
            } catch (SQLException e) {
                System.out.println("Requete creation contact incorrecte");
                e.printStackTrace();
            } catch (ClassNotFoundException cnf) {
                System.out.println("La classe du driver jdbc n'a pu etre chargee");
                cnf.printStackTrace();
            } finally {
                try {
                    conn.close();
                } catch (SQLException e) {
                }
            }
            if(rs >= 0){
     
                new SqlInstructionController().addQuery(query);
            }
            return rs;
        }

  8. #8
    Membre chevronné
    Profil pro
    Fabrication GED
    Inscrit en
    Octobre 2005
    Messages
    1 405
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Fabrication GED

    Informations forums :
    Inscription : Octobre 2005
    Messages : 1 405
    Points : 1 958
    Points
    1 958
    Par défaut
    ? tu peux la refaire en français et si possible sans faute d'orthographe ? Parce que là, j'y comprends rien...

  9. #9
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Février 2005
    Messages
    54
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 54
    Points : 31
    Points
    31
    Par défaut
    non c'est bon j'ai trouvé ;

    c'est sympa de ta part

    you burst me well but one will see;
    The War

Discussions similaires

  1. Réponses: 7
    Dernier message: 27/03/2006, 16h18
  2. [debutant]JDBC+Mysql
    Par dark2 dans le forum JDBC
    Réponses: 1
    Dernier message: 07/03/2006, 08h51
  3. [debutant] jdbc et classpath !!!!
    Par christophebmx dans le forum JDBC
    Réponses: 7
    Dernier message: 12/09/2005, 22h22
  4. [debutant][jdbc]driver introuvable
    Par debdev dans le forum JDBC
    Réponses: 10
    Dernier message: 11/05/2005, 11h52
  5. [debutant][JDBC]
    Par zozolh2 dans le forum Eclipse Java
    Réponses: 1
    Dernier message: 24/05/2004, 18h16

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