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

SQL Oracle Discussion :

Modifier l'enregistrement le plus récent


Sujet :

SQL Oracle

  1. #1
    Membre éclairé
    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2007
    Messages
    346
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Aveyron (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2007
    Messages : 346
    Par défaut Modifier l'enregistrement le plus récent
    Bonjour, tout le monde

    J’ai la table TInfo, cette table contenant les champs suivants :
    TInfo (id, nom, prenom, montant, dateReception)

    Je veux modifier le montant de la personne de nom‘Test1’ par le montant suivant « 12345 » pour la dernière date de réception

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Update TInfo
    Set montant= ‘12345Where nom=’ Test1’ and dateReception = (select max (dateReception) from TInfo)
    Mais cette requête ne fonctionne pas, c'est-à-dire elle n’a modifié aucune ligne

    Et j’essaye aussi cette solution, mais elle a modifié toutes les lignes ce n’est pas que la ligne la plus récente

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Update TInfo
    Set montant= ‘12345Where nom=’ Test1’ 
    Order by dateReception desc
    Est-ce que je dois faire une autre solution ? merci de m’aider

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    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 136
    Par défaut
    Comme cela ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    UPDATE  TInfo   inf
    SET     montant= '12345'
    WHERE   nom = ' Test1'
        AND EXISTS 
            (   SELECT  1 
                FROM    TInfo   dat
                WHERE   inf.nom = dat.nom
                HAVING  inf.dateReception = MAX(dat.dateReception) 
            )
    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.

  3. #3
    Membre éclairé
    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2007
    Messages
    346
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Aveyron (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2007
    Messages : 346
    Par défaut
    Merci pour la rèponse
    Est ce que je dois faire cette solution:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    UPDATE  TInfo   inf
    SET     montant= '12345'
    WHERE   nom = ' Test1' and inf.dateReception =   
            (   SELECT  max(dat.dateReception)
                FROM    TInfo   dat
                WHERE   dat.nom = ' Test1') 
            )
    ou bien :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    UPDATE  TInfo   inf
    SET     montant= '12345'
    WHERE   nom = ' Test1'
        AND EXISTS 
            (   SELECT  1 
                FROM    TInfo   dat
                WHERE   inf.nom = dat.nom
                HAVING  inf.dateReception = MAX(dat.dateReception) 
            )
    Laquelle de ces solutions est la plus performante (gagne du temps, memoire...)

    Merci à vos aides .

  4. #4
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    Seul un test te le dira

Discussions similaires

  1. Liste des enregistrements les plus récents
    Par calagan99 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 19/03/2008, 11h39
  2. Réponses: 5
    Dernier message: 25/01/2008, 20h26
  3. Ne conserver que les N enregistrement les plus récents.
    Par gomodo dans le forum Langage SQL
    Réponses: 2
    Dernier message: 21/01/2008, 19h46
  4. Trouver l'enregistrement le plus récent
    Par PrinceMaster77 dans le forum Langage SQL
    Réponses: 8
    Dernier message: 19/02/2005, 19h14
  5. recup des enregistrement les plus récents.
    Par julien_guy dans le forum Langage SQL
    Réponses: 8
    Dernier message: 29/06/2004, 11h04

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