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 :

Requête avec condition spécifique pour les fonctions LAG / LEAD


Sujet :

Langage SQL

  1. #1
    Candidat au Club
    Homme Profil pro
    Ingénierie industrielle
    Inscrit en
    décembre 2021
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Ingénierie industrielle
    Secteur : Industrie

    Informations forums :
    Inscription : décembre 2021
    Messages : 2
    Points : 2
    Points
    2
    Par défaut Requête avec condition spécifique pour les fonctions LAG / LEAD
    Bonjour à tous,
    J'ai un problème avec une requête SQL, voici ma requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    SELECT
    VP_C.Date_Cub,
    VP_C.Type_Cub,
    LAG(VP_C.Date_Cub) OVER(ORDER BY VP_C.Date_Cub) AS dateAvant,
    LEAD(VP_C.Date_Cub) OVER(ORDER BY VP_C.Date_Cub) AS dateApres
    FROM
    VP_C
    WHERE
    VP_C.Type_Cub LIKE 'P'
    ORDER BY
    VP_C.Date_Cub ASC;
    Je souhaite afficher/extraire seulement les lignes avec VP_C.Type_Cub LIKE 'P' mais je souhaite que les fonctions LAG et LEAD aillent chercher dans la ligne précédente/suivante (en fonction de date/time) toutes lignes confondus -> tous VP_C.Type_Cub confondus (pas seulement : 'p').


    Si vous avez des éléments de réponse à mon problème je suis preneur !

    Je vous remercie par avance
    Vincent

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    mai 2002
    Messages
    8 916
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Val de Marne (Île de France)

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

    Informations forums :
    Inscription : mai 2002
    Messages : 8 916
    Points : 29 815
    Points
    29 815
    Par défaut
    Bonjour,

    Je le ferais en deux étapes :
    1. Calcul des dates précédentes et suivantes
    2. Restriction en fonction du type

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    WITH    srq
        AS  (   SELECT  VP_C.Date_Cub
                    ,   VP_C.Type_Cub
                    ,   LAG(VP_C.Date_Cub) OVER(ORDER BY VP_C.Date_Cub)     AS dateAvant
                    ,   LEAD(VP_C.Date_Cub) OVER(ORDER BY VP_C.Date_Cub)    AS dateApres
                FROM    VP_C
            )
    SELECT  Date_Cub
        ,   Type_Cub
        ,   dateAvant
        ,   dateApres
    FROM    srq
    WHERE   Type_Cub = 'P'
    ORDER BY Date_Cub ASC
    ;
    A noter : l'opérateur LIKE n'est utile que lorsqu'on compare une chaine avec un modèle comportant au moins un caractère générique (% et/ou _). Sinon, il faut utiliser l'opérateur =.
    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
    Candidat au Club
    Homme Profil pro
    Ingénierie industrielle
    Inscrit en
    décembre 2021
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Ingénierie industrielle
    Secteur : Industrie

    Informations forums :
    Inscription : décembre 2021
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    OK top ca fonctionne de cette manière là.

    Merci aussi pour l'info sur l'opérateur LIKE, le = me permet de gagner de temps de chargement des données.

    Vincent

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

Discussions similaires

  1. Requête avec condition pour ouvrir formulaire
    Par YVES3333 dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 19/12/2019, 20h11
  2. Aide pour construire une requête avec condition
    Par Vincent Valentine dans le forum Requêtes
    Réponses: 6
    Dernier message: 08/01/2016, 09h48
  3. Réponses: 5
    Dernier message: 19/02/2015, 19h23
  4. Calcul requête avec conditions multiples
    Par Phullbrick dans le forum Access
    Réponses: 7
    Dernier message: 18/04/2006, 14h45
  5. Pourquoi une seule valeur de retour pour les fonctions ?
    Par Bruno75 dans le forum Langages de programmation
    Réponses: 33
    Dernier message: 18/01/2004, 14h58

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