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

Requêtes et SQL. Discussion :

[Requête UPDATE] copie des valeurs d'un champ


Sujet :

Requêtes et SQL.

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    33
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 33
    Points : 16
    Points
    16
    Par défaut [Requête UPDATE] copie des valeurs d'un champ
    Bonjour, je code sous Access et voici mon problème:

    Je dispose de la table suivante:

    ID...............CHAMP1.................CHAMP2
    1...................NULL......................1
    2...................10.........................1
    3...................NULL......................2
    4....................20........................2

    Je souhaite remplir les valeurs NULL de champ1 avec les valeurs NON NULL de champ1 qui ont le même champ2.

    Exemple:

    ID...............CHAMP1.................CHAMP2
    1...................10.........................1
    2...................10.........................1
    3...................20.........................2
    4....................20........................2

    J'utilise cette requête:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    UPDATE TABLE AS T1 SET T1.CHAMP1 = (select T2.CHAMP1 from Table as T2 where T1.[CHAMP2] = T2.[CHAMP2] and T2.CHAMP1 <> NULL)
    WHERE T1.CHAMP1=Null;
    J'obtiens ce message: "L'opération doit utiliser une requête qui peut être mise à jour"

    Cette requête est-elle correcte?

    Merci.

  2. #2
    Rédacteur/Modérateur

    Avatar de Jean-Philippe André
    Homme Profil pro
    Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Inscrit en
    Juillet 2007
    Messages
    14 629
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Canada

    Informations professionnelles :
    Activité : Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2007
    Messages : 14 629
    Points : 34 334
    Points
    34 334
    Par défaut
    salut,
    c'est pas un peu freestyle ta requete ?
    où récupères-tu une table T ?

    L'idée est bonne sinon.
    Essaie de corriger ton T seul, ca marchera
    Cycle de vie d'un bon programme :
    1/ ça fonctionne 2/ ça s'optimise 3/ ça se refactorise

    Pas de question technique par MP, je ne réponds pas

    Mes ouvrages :
    Apprendre à programmer avec Access 2016, Access 2019 et 2021

    Apprendre à programmer avec VBA Excel
    Prise en main de Dynamics 365 Business Central

    Pensez à consulter la FAQ Excel et la FAQ Access

    Derniers tutos
    Excel et les paramètres régionaux
    Les fichiers Excel binaires : xlsb,

    Autres tutos

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    33
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 33
    Points : 16
    Points
    16
    Par défaut
    Edit il s'agissait de T1.

    L'idée est bonne cela veut dire qu'elle a un sens?

    L'erreur que j'obtiens je ne sais pas du tout comment la corriger mais si tu me dis que la requête est correcte je te fais confiance.

    Merci

  4. #4
    Rédacteur/Modérateur

    Avatar de Jean-Philippe André
    Homme Profil pro
    Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Inscrit en
    Juillet 2007
    Messages
    14 629
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Canada

    Informations professionnelles :
    Activité : Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2007
    Messages : 14 629
    Points : 34 334
    Points
    34 334
    Par défaut
    le mieux reste de passer de ceci :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    UPDATE TABLE T1 SET T1.CHAMP1 = (select T2.CHAMP1 from Table as T2 where T1.[CHAMP2] = T2.[CHAMP2] and T2.CHAMP1 <> NULL)
    WHERE T1.CHAMP1=Null;
    à cela
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    UPDATE T1 INNER JOIN T1 AS T2 INNER JOIN T1.[CHAMP2] = T2.[CHAMP2]
    SET T1.CHAMP1 = T2.CHAMP1 WHERE T1.CHAMP1 IS NULL
    Cycle de vie d'un bon programme :
    1/ ça fonctionne 2/ ça s'optimise 3/ ça se refactorise

    Pas de question technique par MP, je ne réponds pas

    Mes ouvrages :
    Apprendre à programmer avec Access 2016, Access 2019 et 2021

    Apprendre à programmer avec VBA Excel
    Prise en main de Dynamics 365 Business Central

    Pensez à consulter la FAQ Excel et la FAQ Access

    Derniers tutos
    Excel et les paramètres régionaux
    Les fichiers Excel binaires : xlsb,

    Autres tutos

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    33
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 33
    Points : 16
    Points
    16
    Par défaut
    Bonjour, je me suis permis de remplacer le 2eme inner join par un "ON" et ça roule, mais ça devait fonctionner avec 2 inner join?

    Merci en tous cas.

  6. #6
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    62
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2006
    Messages : 62
    Points : 45
    Points
    45
    Par défaut
    à cela
    Code sql :

    UPDATE T1 INNER JOIN T1 AS T2 INNER JOIN T1.[CHAMP2] = T2.[CHAMP2]
    SET T1.CHAMP1 = T2.CHAMP1 WHERE T1.CHAMP1 IS NULL

    OUI IL FAUT METTRE UN ON A LA PLACE DU DEUXIEME INNER JOIN.

    SINON MERCI POUR CE TOPIC, il va me permettre de destituer mon cdp de son poste.

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 01/11/2013, 11h53
  2. Copie des valeurs d'un champ impossible
    Par morgane32 dans le forum Modélisation
    Réponses: 3
    Dernier message: 25/02/2009, 16h08
  3. Regrouper des valeurs de différents champs
    Par Guranga dans le forum Access
    Réponses: 1
    Dernier message: 13/06/2006, 21h54
  4. Réponses: 1
    Dernier message: 19/03/2006, 20h52
  5. Problème de requête avec cumul des conditions sur un champ
    Par UtopieAmbiante dans le forum Requêtes
    Réponses: 4
    Dernier message: 11/01/2006, 10h52

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