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 :

Help sur la jointure!


Sujet :

Langage SQL

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2013
    Messages
    64
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2013
    Messages : 64
    Points : 44
    Points
    44
    Par défaut Help sur la jointure!
    Bonjour,

    J'ai deux tables nommés T1: Id, DateValue, Amount et T2: Id, DateValue, Amount, il faut mettre à jour les valeurs de DateValue dans T1 en recopiant les valeurs correspondantes (via Id) depuis T2 et supprimer les données de T1 pour lesquelles l'Id correspondant n'apparaît pas dans T2.

    J'ai requêté comme la suite pour la première question
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    update test1
    set test1.amount=test2.amount
    where test1 inner join test2 on test1.id=test2.id;
    mais, cela ne fonctionne pas. Je pense que la deuxième question sera la même raisonnement. Quelqu'un peux m'aider,s'il vous plaît.

  2. #2
    Membre éclairé Avatar de GeekMokona
    Femme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Novembre 2011
    Messages
    327
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 44
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Consultant en Business Intelligence
    Secteur : Conseil

    Informations forums :
    Inscription : Novembre 2011
    Messages : 327
    Points : 817
    Points
    817
    Par défaut
    Pour écrire un update avec Jointure , le mieux est dans un premier temps d'écrire le select retournant les Lignes à modifier avec la nouvelle valeur

    Exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Select test2.amount
    From test1 inner join test2 on test1.id=test2.id
    Ce qui donnera une fois transformé en Update


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    Update test1 
     amount = test2.amount
    From test1 inner join test2 on test1.id=test2.id

    sinon quel est ton SGBD ? Car si il support MERGE , regarde cette instruction pour pouvoir à la fois faire les updates si la jointure 'MATCH' et la suppression si la cette même jointure ne 'match' pas car non présente dans la table Test2 .

    Exemple de Code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    Merge into test1 T1
    using  test2 T2
    on T2.id =T1.id
    When matched then Update set valeur= T2.valeur
    When not matched by source then delete;
    Séverine Capon - Consultante MS BI
    Rejoignez la communauté du chat et partagez vos connaissances ou vos questions avec nous

    Merci de dés que le commentaire vous a aidé ou de marquer si votre problème est résolu

  3. #3
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 080
    Points : 30 812
    Points
    30 812
    Par défaut
    Que signifie "cela ne fonctionne pas" ?
    La commande UPDATE sur une jointure n'est pas normalisée. Il est donc fort possible que ton SGBD ne supporte pas cette syntaxe.
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

Discussions similaires

  1. Help sur Jointure EXTERNE
    Par nomissamoht dans le forum Langage SQL
    Réponses: 6
    Dernier message: 12/03/2009, 16h18
  2. Débutant SQL, problème sur une jointure censée exclure ??
    Par derfatypik dans le forum Langage SQL
    Réponses: 8
    Dernier message: 22/06/2005, 15h55
  3. limitation du nombre d'enregistrement sur une jointure
    Par coredump dans le forum Langage SQL
    Réponses: 2
    Dernier message: 18/06/2005, 16h13
  4. un count sur une jointure et ca ne fonctionne pas
    Par elbronziero dans le forum Langage SQL
    Réponses: 2
    Dernier message: 14/10/2004, 11h23
  5. help sur le code d'une procedures stockee
    Par omlip dans le forum MS SQL Server
    Réponses: 6
    Dernier message: 25/08/2004, 18h45

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