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 :

comment faire ce update svp?


Sujet :

Bases de données Delphi

  1. #1
    iam
    iam est déconnecté
    Membre régulier
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    197
    Détails du profil
    Informations personnelles :
    Localisation : Algérie

    Informations forums :
    Inscription : Novembre 2005
    Messages : 197
    Points : 72
    Points
    72
    Par défaut comment faire ce update svp?
    est ce quelqu'un a rencontré dèjà ce pb ou sait comment le faire, je l'ai besoin fortement :
    je veux faire une requete de mise à jour suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    update marque set mrqlib=(select marquetmp.mrqlib from marquetmp where marque.mrqcod=marquetmp.mrqcod);
    je faire un update du champ mrqlib dans la table marque à partir le meme champ mrqlib situé dans une autre table marquetmp.

    elle m'affiche ce message quand je l'execute : l'opération doit utiliser une requete qui peut etre mise à jour
    qu'est ce que je doit faire pour mettre à jour une table à partir d'une autre table dans le meme schéma de base de données ou différent, j'utilise une base de données Access avec ADO, merci

  2. #2
    Membre éclairé
    Avatar de gerald2545
    Profil pro
    Inscrit en
    Février 2003
    Messages
    744
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2003
    Messages : 744
    Points : 773
    Points
    773
    Par défaut
    bonjour,
    utilise la balise [CODE] (bouton # de l'éditeur de message), ce sera plus compréhensible merci d'avance.
    1/ Ta sous-requete est erronée
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select marquetmp.mrqlib from marquetmp where marque.mrqcod=marquetmp.mrqcod
    tu n'as pas mis la table marque dans la clause FROM
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select marquetmp.mrqlib from marquetmp, marque where marque.mrqcod=marquetmp.mrqcod
    .

    2/ ta sous-requete va te retourner de multiples enregistrements je présume, donc tu ne peux pas t'en servir pour mettre à jour ton champs mrqlib (1 seule valeur est obligatoire)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    update marque set mrqlib=
    3/ dans ton code tu ne précises pas quel enregistrement mettre à jour, donc si tu arrives à ne retourner qu'une seule valeur dans ta sous-requête, tous les enregistrrements de ta table marque vont prendre cette valeur pour le champs mrqlib...

    Désolé, je ne connais pas la requête à effectuer pour arriver à ce que tu veux

  3. #3
    iam
    iam est déconnecté
    Membre régulier
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    197
    Détails du profil
    Informations personnelles :
    Localisation : Algérie

    Informations forums :
    Inscription : Novembre 2005
    Messages : 197
    Points : 72
    Points
    72
    Par défaut eclaircissement sur le update
    merci gerald pour tes eclaircissements, en faite je veux mettre à jour chaque champs MRQLIB dans MARQUE, par son correspondant MRQLIB dans MARQUETMP garantit par cette jointure MARQUE.MRQCO=MARQUETMP.MRQCOD, je sais que d'après ce que tu m'as dis tout les champs mrqlib de la table destination vont etre mise à jour avec la meme valeur, mais moi je ne veux pas ça, je veux que chaque mrqlib est mise à jour avec la valeur correspondante selon le MRQCOD
    j'espère que c'est clair ma question

  4. #4
    iam
    iam est déconnecté
    Membre régulier
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    197
    Détails du profil
    Informations personnelles :
    Localisation : Algérie

    Informations forums :
    Inscription : Novembre 2005
    Messages : 197
    Points : 72
    Points
    72
    Par défaut
    ca marche pas meme si j'ajoute la table marque dans la clause from
    il m'affiche (l'opération doit utiliser une requete qui peut etre mise à jour)

  5. #5
    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
    (l'opération doit utiliser une requete qui peut etre mise à jour)
    ça ressemble à un query.open à la place d'un query.execSQL
    Cette seule syntaxe permet l'exécution d'un update ou d'un delete...

  6. #6
    Membre éclairé
    Avatar de gerald2545
    Profil pro
    Inscrit en
    Février 2003
    Messages
    744
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2003
    Messages : 744
    Points : 773
    Points
    773
    Par défaut
    c'est pour ce genre de choses qu'il est important de mettre son code en copie pour voir plus facilement d'où peut provenir une erreur.

    Je ne sais pas si c'est possible de réaliser ce que tu désires avec une seule requête.....si des pros sont dans le coin, qu'ils apportent leurs lumières.

    Sinon, tu peux le réaliser en prog :
    - sélectionne tous les mrqcod from marque
    - pour chaque marque.mrqcod MM:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    UPDATE marque SET mrqlib=(SELECT marquetmp.mrqlib FROM marquetmp WHERE marquetmp.mrqcod=MM) WHERE mrqcod = MM;

  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
    Citation Envoyé par gerald2545
    c'est pour ce genre de choses qu'il est important de mettre son code en copie pour voir plus facilement d'où peut provenir une erreur.
    Entièrement d'accord.

    Citation Envoyé par gerald2545
    Je ne sais pas si c'est possible de réaliser ce que tu désires avec une seule requête.....
    Oui, et je pense qu'il est sur la bonne voie.

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

Discussions similaires

  1. Comment faire un UPDATE partiel?
    Par EmmanuelleC dans le forum Langage SQL
    Réponses: 2
    Dernier message: 12/07/2008, 18h52
  2. Comment faire un update de la ligne 5 à la ligne 17
    Par bassiste dans le forum Langage SQL
    Réponses: 5
    Dernier message: 03/07/2008, 17h36
  3. Comment faire l'Update
    Par andy38 dans le forum VBA Access
    Réponses: 1
    Dernier message: 03/02/2007, 11h51
  4. Réponses: 1
    Dernier message: 07/09/2006, 16h03
  5. [VB6] Comment faire un update sur des textbox qui sont créés
    Par bb62 dans le forum VB 6 et antérieur
    Réponses: 27
    Dernier message: 16/02/2006, 14h52

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