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

Oracle Discussion :

Mise à jour d'une table


Sujet :

Oracle

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    22
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2005
    Messages : 22
    Points : 11
    Points
    11
    Par défaut Mise à jour d'une table
    bonjour à tous,
    j'ai une table qui possède 4 colonnes. J'aimerais mettre à jour la quatrième colonne de deux ou plusieurs enregistrements si la deuxième et la troisième colonne comportent les mêmes valuers.

    Exemple:

    a1 a2 a3 a4

    1 10 20 null
    2 a b null
    3 10 20 null
    4 a b null
    5 f g null



    après mise à jour


    a1 a2 a3 a4

    1 10 20 t
    2 a b u
    3 10 20 t
    4 a b u
    5 f g null


    comment puis-je effectuer ceci
    merci

  2. #2
    Membre expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Points : 3 609
    Points
    3 609
    Par défaut
    Je ne suis pas sûr d'avoir tout compris :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    update matable
    set a4 = 't'
    where a1 = '10'
      and a2 = '20';
    Merci de penser aux balises code pour plus de lisibilité.
    Un problème sans solution est un problème mal posé

    Merci de poser vos questions sur le forum, je ne réponds pas aux questions posées par MP.

  3. #3
    Membre habitué Avatar de VinceTlse
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    163
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Janvier 2005
    Messages : 163
    Points : 191
    Points
    191
    Par défaut
    Je pense que c'est pas ce que veux dire bath.

    Si on considere les ligne 1 & 3, leur colonnes A2 et A3 sont identiques. Donc Bath veut les lier en renseignant la colonne A4 des lignes.

    Pareil pour les lignes 2 & 4.

    Par contre la pauvre ligne 5 n'a pas de ligne ayant les meme colonnes A2 et A3 donc sa colonne A4 reste a null.

    Par simplicité je le ferais en PL/SQL mais je sais pas si une requete toute simple est faisable. Le probleme vient de la colonne 4. Est ce que la donnée a mettre doit etre unique?
    Pourquoi faire aujourd'hui ce que l'on peut faire demain ...

  4. #4
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    22
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2005
    Messages : 22
    Points : 11
    Points
    11
    Par défaut
    Merci pour votre réponse, mais ma question est de savoir comment
    mettre à jour la colonne a4 de ma table pour tous les enregistrements
    qui ont les mêmes valuers dans les colonnes a2 et les mêmes valeurs

    dans les colonnes a3
    en un seul update.

    l'idée est de rapprocher toutes les lignes d'une table qui ont
    les mêmes valeurs dans deux colonnes.
    la colonne a4 contiendra la même valeur pour deux enregistrement rapprochés.

    en un seul update si possible
    merci

  5. #5
    McM
    McM est déconnecté
    Expert éminent

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Points : 7 740
    Points
    7 740
    Billets dans le blog
    4
    Par défaut
    Est-ce que j'ai bien compris, tu veux mettre à jour a4 s'il existe un autre doublon (a2,a3) dans ta table ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    UPDATE MATABLE T1
    SET a4 = 't'
    WHERE EXISTS (	SELECT 1 
    				FROM MATABLE T2
    				WHERE T2.a1 <> T1.a1
    				AND T2.a2 = T1.a2
    				AND T2.a3 = T1.a3
    				)
    Maintenant si tu veux mettre dans a4 un code différent suivant le doublon (a2,a3), tu n'as qu'a les concaténer en insérant un séparateur qui n'existe pas dans a2 ou a3
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    UPDATE MATABLE T1
    SET a4 = a2 || '#@#' || a3
    WHERE EXISTS (	SELECT 1 
    				FROM MATABLE T2
    				WHERE T2.a1 <> T1.a1
    				AND T2.a2 = T1.a2
    				AND T2.a3 = T1.a3
    				)
    More Code : More Bugs. Less Code : Less Bugs
    Mon Blog PL/Sql : Fichier Zip / Image BMP / Lire sqliteDB / QRCode et Images PNG ou BMP

  6. #6
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    22
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2005
    Messages : 22
    Points : 11
    Points
    11
    Par défaut
    thank you. It 's exactetly what i need
    many thanks

Discussions similaires

  1. Mise à jour d'une table à partir d'un sous formulaire
    Par Daniel MOREAU dans le forum Access
    Réponses: 1
    Dernier message: 02/11/2005, 20h07
  2. Mise à jour d'une table
    Par smotte76 dans le forum Access
    Réponses: 2
    Dernier message: 31/10/2005, 18h13
  3. Mise à jour d'une table avec un fichier csv
    Par blackangel dans le forum PostgreSQL
    Réponses: 4
    Dernier message: 26/05/2005, 14h46
  4. Réponses: 5
    Dernier message: 06/01/2005, 12h07
  5. mise à jour d'une table d'interbase sous delphi
    Par kouraichi35 dans le forum Bases de données
    Réponses: 2
    Dernier message: 19/10/2004, 13h09

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