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 :

Update avec RANK


Sujet :

Langage SQL

  1. #1
    Membre à l'essai
    Inscrit en
    Mai 2003
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Mai 2003
    Messages : 16
    Points : 11
    Points
    11
    Par défaut Update avec RANK
    Bonjour

    voici mon souci : je possède une table historisant l'occupation de logements. Pour chaque logement on a donc un code correspondant au statut d'occupation et à une date donnée (date de début du statut).
    Je souhaite rajouter une colonne qui serait la date de fin de statut et alimentée avec la date de début du statut suivant - 1 jour.

    Illustration :

    Table LGT_OCCUP
    ID_LGT --- COD_OCCU ---- DATEDEB ------ DATEFIN
    ----------------------------------------------------
    1 ________Vacant ______01/01/2007_____31/05/2007
    2 ________Travaux _____01/06/2007_____30/06/2007
    3 ________Occupé______01/07/2007

    J'ai tenté un update avec un RANK mais sans parvenir à mes fins (erreur ORA-30483). Mon problème c'est la recherche du statut suivant.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    UPDATE LGT_OCCUP
    SET DATEFIN = 
    (SELECT A.DATEDEB
     FROM (SELECT ID_LGT, DATEDEB, 
                  RANK() OVER (PARTITION BY ID_LGT ORDER BY DATEDEB) as RANG
                  FROM LGT_OCCUP) A
                WHERE 
                  LGT_OCCUP.ID_LGT = A.ID_LGT
                  and RANK() OVER (PARTITION BY ID_LGT ORDER BY DATEDEB) = rang +1
            )
            and LGT_OCCUP.DATEFIN is null ;
    Est ce que je peux reussir à alimenter ce champ avec cette méthode ?
    Merci de votre aide

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 102
    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 102
    Points : 28 387
    Points
    28 387
    Par défaut
    Et que signifie l'erreur ORA-30483 pour ceux qui ne connaissent pas la documentation Oracle sur le bout des doigts ?

  3. #3
    Membre à l'essai
    Inscrit en
    Mai 2003
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Mai 2003
    Messages : 16
    Points : 11
    Points
    11
    Par défaut
    L'erreur ORA-30483 signifie : "Fonction de fenêtrage interdite ici".
    La fonction en question est le RANK() et je l'utilise comme argument (cf. avant dernière ligne) alors que ce genre de fonction n'est possible que dans un SELECT.

  4. #4
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 102
    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 102
    Points : 28 387
    Points
    28 387
    Par défaut
    Et pourquoi ne pas essayer de faire plus simple ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    UPDATE  lgt_occup
    SET     datefin = 
            (   SELECT  MIN(a.datedeb) - 1
                FROM    lgt_occup   AS a
                WHERE   lgt_occup.id_lgt = a.id_lgt
                    AND lgt_occup.datedeb < a.datedeb
            )
            AND lgt_occup.datefin IS NULL
    ;

  5. #5
    Membre à l'essai
    Inscrit en
    Mai 2003
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Mai 2003
    Messages : 16
    Points : 11
    Points
    11
    Par défaut
    oui c'est vrai que c'est plus simple
    j'étais parti sur le RANK par souci d'optimisation et par curiosité aussi mais ta méthode est sûrement la meilleure.
    Est ce qu'une requête avec le RANK peut marcher toutefois ? et serait-ce plus rapide ?

    merci

  6. #6
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 102
    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 102
    Points : 28 387
    Points
    28 387
    Par défaut
    Citation Envoyé par maestro12 Voir le message
    Est ce qu'une requête avec le RANK peut marcher toutefois ?
    Certainement, mais pour utiliser une fonction de regroupement analytique dans un test, il faut un niveau de sous-requête supplémentaire.
    Cette syntaxe est interdite :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT  a,b,c
    FROM    matable
    WHERE   FUNCTION(*) OVER(xxx) = valeur
    ou
    HAVING  FUNCTION(*) OVER(xxx) = valeur
    ;
    Mais on peut faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT  a,b,c
    FROM    (   SELECT  a,b,c
                    ,   FUNCTION(*) OVER(xxx)   AS res
                FROM    matable
            )   AS sub
    WHERE   sub.res = valeur
    ;
    Citation Envoyé par maestro12 Voir le message
    et serait-ce plus rapide ?
    Il faut tester, consulter les plans d'exécution, ...

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. UPDATE avec JOIN ?
    Par zakuli dans le forum Débuter
    Réponses: 3
    Dernier message: 25/07/2007, 14h53
  2. UPDATE avec des variables Delphi ...
    Par Kokito dans le forum Bases de données
    Réponses: 3
    Dernier message: 08/03/2004, 22h35
  3. Requete d'update avec concatenation !!
    Par chris92 dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 25/02/2004, 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