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 :

Update récalcitrant !


Sujet :

Bases de données Delphi

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Juin 2004
    Messages
    91
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 91
    Points : 36
    Points
    36
    Par défaut Update récalcitrant !
    Bonjour,
    Je bute sur cette requête
    with ADOQuery1 do begin
    SQL.Clear;
    SQL.Add('UPDATE landry SET');
    SQL.Add('AUTEURS=:CAuteur1, OUVRAGES=:CTitre1, LIEU=:CEtage1 WHERE');
    SQL.Add('AUTEURS=:CAuteur, OUVRAGES=:CTitre, LIEU=:CEtage ');
    ADOQuery1.Prepared:=True;
    ExecSQL;
    end;
    Je précise :
    Les variables CAuteur1, CTitre1 et CEtage1 contiennent les nouvelles valeurs
    Les variables CAuteur, CTitre et CEtage les anciennes
    J'ai constamment l'erreur me diant que Objet Parameter defini de manière incorrect Des informations incohérentes ou incomplètes ont été fournies !
    Un petit coup de main serait le bienvenu !
    merci

  2. #2
    Expert éminent sénior

    Avatar de Nono40
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2002
    Messages
    8 640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2002
    Messages : 8 640
    Points : 19 101
    Points
    19 101
    Par défaut
    Fait voir le code de mise à jour des paramètres stp...
    Delphi :
    La F.A.Q. , 877 réponses à vos questions !
    264 sources à consulter/télécharger !

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Juin 2004
    Messages
    91
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 91
    Points : 36
    Points
    36
    Par défaut
    voilà :
    Parameters.ParamByName('CAuteur').Value := CAuteur1;
    Parameters.ParamByName('CTitre').Value := CTitre1;
    Parameters.ParamByName('CEtage').Value := CEtage1;

    je pense que c'est ça !

    ces lignes sont mises avant le ADOQuery.Prepared
    et merci pour cette réponse rapide !

  4. #4
    Membre averti
    Profil pro
    xxxxxxxxxxx
    Inscrit en
    Juin 2004
    Messages
    308
    Détails du profil
    Informations personnelles :
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : xxxxxxxxxxx

    Informations forums :
    Inscription : Juin 2004
    Messages : 308
    Points : 407
    Points
    407
    Par défaut
    Il pourrait s'agir d'un problème dans la construction implicite des paramètres (genre type ftUnknown).
    As-tu fait l'essai de mettre le texte SQL à la conception dans l'ADOQuery, et de consulter ses 'Parameters' ?
    Voir aussi la propriété ParamCheck...

  5. #5
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Juin 2004
    Messages
    91
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 91
    Points : 36
    Points
    36
    Par défaut
    salut,
    Dans la construction implicite des paramètres les trois sont de type ftString.
    Quand à la propriété ParmaCheck elle est à true !
    Non j'ai pas essayé de mettre le texte SQL à la conception car je fais plusieurs requêtes différentes avec le même TADOQuery.

    La première pour trouver l'enregistrement donc avec un select et là ca fonctionne parfaitement, puis après les modifs, je cherche donc à modifier l'enregistrement.

    Mais je vais peut-être essayer en mettant un deuxième TADOQuery !
    je vais voir et vous tiens au courant
    merci pour la réponse !

  6. #6
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Juin 2004
    Messages
    91
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 91
    Points : 36
    Points
    36
    Par défaut
    re salut,
    bon après avoir créé un 2ème TADOQuery puis à la conception mis le teste suivant dans le SQL :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    UPDATE landry SET AUTEURS=:titre1, OUVRAGES=:titre, LIEU=:titre2
    WHERE OUVRAGES=:titre4
    puis changé la boucle de la manière suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
     with ADOQuery2 do begin
                 Parameters.ParamByName('titre1').Value:=CAuteur1;
                 Parameters.ParamByName('titre').Value:=CTitre1;
                 Parameters.ParamByName('titre2').Value:=CEtage1;
                 Parameters.ParamByName('titre4').Value:=CTitre;
                 ADOQuery2.Prepared:=True;
                 ExecSQL;
                 end;
    ca a l'air de fonctionner !
    Mais ne risquerais-je pas un problème en cas de deux ouvrages qui auraient le même titre ?
    CVest un programme destiné à retrouver des livres rangés dans une bibliothèque !

    En tous cas un grand merci pour votre aide

  7. #7
    Membre averti
    Profil pro
    xxxxxxxxxxx
    Inscrit en
    Juin 2004
    Messages
    308
    Détails du profil
    Informations personnelles :
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : xxxxxxxxxxx

    Informations forums :
    Inscription : Juin 2004
    Messages : 308
    Points : 407
    Points
    407
    Par défaut
    Effectivement la mise à jour se fera sur tous les livres portant le titre passé en clause where de l'update.
    En principe pour éviter cela, on crée une clé primaire assurant l'unicité d'enregistrement dans la base.

    Bon courage.

  8. #8
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Juin 2004
    Messages
    91
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 91
    Points : 36
    Points
    36
    Par défaut
    Oui, je me doutais bien de la chose !
    C'est la raison pour laquelle je voulais prendre en compte le nom de l'auteur et le nom de l'ouvrage !
    Mais je vais voir pour recréer la base avec une clé primaire!
    Dans ce cas, je mettrais la clé dans la close WHERE !

    enfin merci beaucoup, mais je comprends pas pourquoi la 1ère méthode ne voulait pas fonctionner !


  9. #9
    Membre averti
    Profil pro
    xxxxxxxxxxx
    Inscrit en
    Juin 2004
    Messages
    308
    Détails du profil
    Informations personnelles :
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : xxxxxxxxxxx

    Informations forums :
    Inscription : Juin 2004
    Messages : 308
    Points : 407
    Points
    407
    Par défaut
    rien ne t'empêche non plus d'établir une clause where telle que
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ...WHERE OUVRAGES=:titre4 AND AUTEURS=:auteur
    En fait, ce qu'il faut retenir, c'est qu'en affectant dynamiquement le texte SQL à un objet Query, on remet en cause les paramètres qui avaient pu être "parsés" (analysés) dans le mode conception.
    Dès lors, ces paramètres potentiellement recréés ne seront peut-être pas directement utilisables.

    N'oublies pas d'utiliser le tag résolu si tu estimes que c'est le cas.

  10. #10
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Juin 2004
    Messages
    91
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 91
    Points : 36
    Points
    36
    Par défaut
    oui, je vais essayer cette solution !

  11. #11
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Juin 2004
    Messages
    91
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 91
    Points : 36
    Points
    36
    Par défaut
    Salut,
    Oui, tout marche comme sur des roulettes
    encore une fois milles mercis

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

Discussions similaires

  1. Requête update à partir d'une autre table
    Par amiral thrawn dans le forum Langage SQL
    Réponses: 5
    Dernier message: 15/02/2024, 11h40
  2. windows update récalcitrant
    Par Lionel_aw dans le forum Windows XP
    Réponses: 0
    Dernier message: 10/10/2008, 11h23
  3. [dBase]il y a mieux que la commande sql UPDATE ?
    Par sana72 dans le forum Autres SGBD
    Réponses: 4
    Dernier message: 12/12/2002, 11h59
  4. Réponses: 3
    Dernier message: 10/11/2002, 11h03
  5. update et virgule
    Par Delph dans le forum Bases de données
    Réponses: 8
    Dernier message: 27/08/2002, 14h40

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