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

Langage SQL Discussion :

Replace par jointure


Sujet :

Langage SQL

  1. #1
    Membre régulier
    Homme Profil pro
    Analyste fonctionnel
    Inscrit en
    Octobre 2021
    Messages
    110
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Analyste fonctionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2021
    Messages : 110
    Points : 109
    Points
    109
    Par défaut Replace par jointure
    Bonjour,

    Je voudrais remplacer des colonnes sur une même table différencié par la colonne "COA_0" comme dans la capture ci-après.
    Je crois savoir que c'est possible en utilisant une jointure ...

    Nom : requete.PNG
Affichages : 172
Taille : 96,5 Ko

    Lorsque COA_0='BEG' et ACCCOD_0 est le même pour COA_0='BEG' et COA_0='FRA' alors remplacer la valeur de ACC_0 (COA=BEG) par ACC_0 (COA=FRA) et ainsi de suite pour ACC_1, ACC_2 etc ...

    Les scripts de lecture qui ont donné cette capture d'écran sont :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    SELECT [COA_0]
          ,[ACCCOD_0]
          ,[DES_0]
          ,[ACC_0]
          ,[ACC_1]
          ,[ACC_2]
          ,[ACC_3]
          ,[ACC_4]
          ,[ACC_5]
          ,[ACC_6]
          ,[ACC_7]
          ,[ACC_8]
    FROM [database].[SCHEMA].[TABLE] WHERE COA_0='FRA'
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    SELECT [COA_0]
          ,[ACCCOD_0]
          ,[DES_0]
          ,[ACC_0]
          ,[ACC_1]
          ,[ACC_2]
          ,[ACC_3]
          ,[ACC_4]
          ,[ACC_5]
          ,[ACC_6]
          ,[ACC_7]
          ,[ACC_8]
    FROM [database].[SCHEMA].[TABLE] WHERE COA_0='BEG'
    Pouvez-vous m'aider svp ?

    Merci d'avance

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 197
    Points : 12 772
    Points
    12 772
    Par défaut
    Bonjour,
    Comme tu l'indiques dans la question, il faut passer ici par une jointure:
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    select t2.COA_0,t1.ACCCOD_0,...
    from LaTable as t1
    inner join LaTable as t2
    on t1.ACCCOD_0 = t2.ACCCOD_0
    where t1.COA_0 = 'FRA' and t2.COA_0 = 'BEG'
    Tu n'as alors plus qu'à choisir dans la clause SELECT les colonnes que tu veux: depuis t1 si tu veux celles issues des lignes dont COA_0 vaut FRA, de t2 dans le cas contraire.
    Il faut également vérifier le type de jointure, pour gérer les cas où il n'y a pas de correspondance.
    Que ce passe t'il par exemple s'il n'y a pas de ligne qui vérifie COA_0 = 'BEG', ou COA_0 = 'FRA' ?
    De la réponse dépendra la jointure à utiliser, et potentiellement la clause SELECT (avec un COALESCE, IFNULL...).

    Tatayo.

  3. #3
    Membre régulier
    Homme Profil pro
    Analyste fonctionnel
    Inscrit en
    Octobre 2021
    Messages
    110
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Analyste fonctionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2021
    Messages : 110
    Points : 109
    Points
    109
    Par défaut
    Rebonjour,

    En fait je voudrais remplacer (REPLACE).
    Le script-là c'est juste pour afficher :-)

  4. #4
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 197
    Points : 12 772
    Points
    12 772
    Par défaut
    Par remplacer, tu veux dire mettre à jour les données dans la base, donc faire un update ?
    Suivant le SGBD utilisé, tu peux faire une jointure dans un update:
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    update t1
    set t1.col1 = t2.col1
    from LaTable as t1
    inner join LaTable as t2
    on ...
    where ...
    Tu peux trouver des explications , par exemple

    Il ne reste plus qu'à adapter la requête que je t'ai donnée dans mon premier message.

    Tatayo.

  5. #5
    Membre régulier
    Homme Profil pro
    Analyste fonctionnel
    Inscrit en
    Octobre 2021
    Messages
    110
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Analyste fonctionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2021
    Messages : 110
    Points : 109
    Points
    109
    Par défaut
    oui, c'est exactement cela, UPDATE, j'ai utilisé abusivement REPLACE :-)
    je te remercie, je pense que ça va aller là

Discussions similaires

  1. Rapidite de traitement par jointure ou par fonction
    Par garciajulien dans le forum Optimisations
    Réponses: 11
    Dernier message: 09/03/2010, 12h36
  2. textbox.Text.Replace ' par '' impossible
    Par beren.kei dans le forum Windows Forms
    Réponses: 3
    Dernier message: 24/06/2008, 14h41
  3. rejoindre des tables liée par jointure
    Par guy88 dans le forum Modélisation
    Réponses: 3
    Dernier message: 28/08/2007, 11h11
  4. Réponses: 5
    Dernier message: 05/07/2007, 08h53
  5. Macro Excel selection.replace . par ,
    Par bentlse dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 26/02/2007, 19h12

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