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

Bases de données Delphi Discussion :

[MySQL] Requête qui ne passe pas


Sujet :

Bases de données Delphi

  1. #1
    Membre à l'essai
    Inscrit en
    Mai 2006
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 13
    Points : 14
    Points
    14
    Par défaut [MySQL] Requête qui ne passe pas
    Bonjour,

    J'utilise delphi 7 avec le connecteur ODBCExpress pour me connecter à la BD MySQL. Toutes mes requetes passent bien jusqu'au moment ou j'essaye de passer une requète contenant une url. la requete est du type :

    'update infor set url = "http://xxxxxxxxx.fr" where ref= "F012547-01"'

    Il semblerait que Delphi soit faché avec les caractères ://
    Quelqu'un a t'il déja rencontré ces problèmes ?

    Kirian

  2. #2
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

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

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    Peux tu montrer le code qui permet de lancer cette requete ?

    Car je pense que ton problème vient du fait d'un problème de quote ['] à la place des ["].

    Et il serait bien que tu nous donnes le messag d'erreur.

  3. #3
    Membre à l'essai
    Inscrit en
    Mai 2006
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 13
    Points : 14
    Points
    14
    Par défaut
    Je pense avoir ciblé correctement le problème et il vient du ":" (suivi de 2 lettres, il passe sans problèmes, suivi de // ca plante)

    Voici le code modifié afin que la requete passe correctement :

    OEQuery1.SQL.Text := 'update infor set email = "' + ansireplacestr(Numero,':','#') + '" where ref= "'+ Ref + '"'

    avec Numero correspondant a la variable contenant l'URL:

    Cependant ça ne me convient pas car je ne peux pas exploiter directement la table MySQL.
    Je suis obligé de refaire un traitement derrière.

  4. #4
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

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

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    Ton problème vient du fait que c'est des ' et pas des " qu'il faut mettre pour MYSQL.

    sinon tu as 2 moyens pour régler ton problème :

    - Soit en utilisant QuotedStr plutot de des multiple " dans tous les sens

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    With OEQuery1 do
    begin
      SQL.Clear;
      SQL.Add('update infor');
      SQL.Add('set email = ' + QuotedStr(Numero));
      SQL.Add('where ref= ' + QuotesStr(Ref));
    end;
    - Soit en passant par des paramètres

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    With OEQuery1 do
    begin
      SQL.Clear;
      SQL.Add('update infor');
      SQL.Add('set email = :EMAIL');
      SQL.Add('where ref= :REF');
      // Faudrat peut être voir si c'est comme cela que ca s'ecrit, 
      //la je fais comme si c'etait des composants de bases de delphi
      // donc a toi d'adapter
      ParamCheck := True;
      ParamByName('EMAIL').Value := Numero;
      ParamByName('REF').Value := Ref;
    end;

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

Discussions similaires

  1. une requète qui ne passe pas
    Par JeanNoel53 dans le forum SQL
    Réponses: 0
    Dernier message: 14/12/2010, 10h47
  2. [ODBC] Requête qui ne passe pas
    Par tom06440 dans le forum PHP & Base de données
    Réponses: 19
    Dernier message: 22/08/2008, 23h29
  3. [MYSQL 5] Requete qui ne passe pas?
    Par sirbaldur dans le forum Requêtes
    Réponses: 1
    Dernier message: 14/11/2006, 15h01
  4. [php-mysql] requête qui ne marche pas....
    Par sanosuke85 dans le forum Requêtes
    Réponses: 1
    Dernier message: 09/01/2006, 17h18
  5. Requête qui ne passe pas
    Par TheBart dans le forum Langage SQL
    Réponses: 2
    Dernier message: 10/08/2005, 10h12

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