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 :

Update avec order by


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    31
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2007
    Messages : 31
    Par défaut Update avec order by
    Bonjour et bonne année à tous,

    Je m'excuse si la question a déjà été posée, ce qui me semble probable, mais je n'ai pas trouvé...

    Voici mon code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    update cmc_sim_simulation 
    set id_person = 
    nvl((select pim_id from etl_out_quoterequest
    where sales_process_id = id_simulation
    and pim_id is not null
    and rownum = 1
    and processed = 0
    order by time_stamp desc), id_person);
    et l'erreur que j'obtiens: ORA-00907: missing right parenthesis


    Je cherche en fait à faire mettre dans le champ id_person le pim_id le plus récent trouvé pour la simulation dans la table etl_out_quoterquest

  2. #2
    Membre chevronné
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    354
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 354
    Par défaut
    Il faut mettre nvl dans le select ...

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    31
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2007
    Messages : 31
    Par défaut
    ça ne marche pas mieux comme ça...

    Et avec le nvl en dehors, si je retire la clause order by ça fonctionne

  4. #4
    Expert confirmé
    Homme Profil pro
    Big Data / Freelance EURL
    Inscrit en
    Mars 2003
    Messages
    2 124
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Big Data / Freelance EURL

    Informations forums :
    Inscription : Mars 2003
    Messages : 2 124
    Par défaut
    normal le ORDER BY est interdit dans l'UPDATE.

    Regardes ce lien qui réponds aussi par la négation sur l'utilisation de ORDER BY dans UPDATE, et donnes quelques pistes.

    edit: Expliques ce que tu cherches à faire.

  5. #5
    Expert confirmé
    Homme Profil pro
    Big Data / Freelance EURL
    Inscrit en
    Mars 2003
    Messages
    2 124
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Big Data / Freelance EURL

    Informations forums :
    Inscription : Mars 2003
    Messages : 2 124
    Par défaut
    Citation Envoyé par angebe Voir le message
    Je cherche en fait à faire mettre dans le champ id_person le pim_id le plus récent trouvé pour la simulation dans la table etl_out_quoterquest
    En relisant ta requête je te proposes quelque chose comme cela:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    UPDATE cmc_sim_simulation 
    SET id_person = (
        SELECT id_person FROM etl_out_quoterequest
        WHERE (pim_id,sales_process_id,time_stamp) IN 
            (SELECT pim_id,sales_process_id,MAX(time_stamp)
            FROM etl_out_quoterequest
            WHERE pim_id IS NOT NULL
            AND processed = 0
            GROUP BY pim_id,sales_process_id
            )
         AND    sales_process_id = id_simulation
        )

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    31
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2007
    Messages : 31
    Par défaut
    Merci mais je pense avoir la solution, il fallait faire un 2ème niveau de sous-requête:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    update cmc_sim_simulation 
    set id_person = 
    nvl(
    (select pim_id 
    from 
    (select pim_id, sales_process_id from etl_out_quoterequest
    where processed = 0
    order by time_stamp desc) 
    where sales_process_id = id_simulation and rownum = 1)
    , id_person);
    C'est en cours de test (ce n'est qu'un morceau d'un long script)

Discussions similaires

  1. [AC-2007] Update avec un order by ?
    Par Counda_T dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 15/01/2013, 14h58
  2. Réponses: 5
    Dernier message: 19/04/2009, 17h06
  3. Réponses: 5
    Dernier message: 10/07/2006, 12h05
  4. [version] Requete Update avec différentes versions de mySQL
    Par regbegpower dans le forum Requêtes
    Réponses: 2
    Dernier message: 26/01/2004, 17h19
  5. Pb Update avec chaine de caractere
    Par JuJu° dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 28/05/2003, 15h58

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