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

Développement SQL Server Discussion :

Jointure sur date immédiatement supérieure


Sujet :

Développement SQL Server

  1. #1
    Candidat au Club
    Homme Profil pro
    Responsable de service informatique
    Inscrit en
    mai 2021
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Responsable de service informatique
    Secteur : Bâtiment

    Informations forums :
    Inscription : mai 2021
    Messages : 3
    Points : 2
    Points
    2
    Par défaut Jointure sur date immédiatement supérieure
    Bonjour
    JE me retrouve bloqué par une requête que je n'arrive pas à écrire servant à relier l'activation d'un évènement à sa désactivation
    Considérons les deux tables suivantes
    Nom : Ssms_DOyNlNZwRS.png
Affichages : 58
Taille : 40,7 Ko
    Je souhaiterais lié la table 1 avec la table 2 en utilisant cette règle
    l'évènement de la table 1 doit être liée avec l'évènement de la table 2 dont l'id est identique et sa date de changement est immédiatement supérieure
    .
    Quelqu'un aurait-il une idée, car je sèche vraiment.
    Merci d'avance

  2. #2
    Modérateur

    Homme Profil pro
    Consultant Teradata
    Inscrit en
    septembre 2008
    Messages
    8 133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Consultant Teradata

    Informations forums :
    Inscription : septembre 2008
    Messages : 8 133
    Points : 16 376
    Points
    16 376
    Par défaut
    Est-ce une seule et même table ou y en a-t-il deux distinctes ?
    Quelle est votre version de SQL-Server ?

  3. #3
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Ingénieur d'études décisionnel
    Inscrit en
    mai 2002
    Messages
    8 758
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur d'études décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : mai 2002
    Messages : 8 758
    Points : 29 226
    Points
    29 226
    Par défaut
    Quelque chose dans ce goût là (à vérifier)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    select  tb1.*
        ,   tb2.*
    from    table_1 tb1
        inner join
            table_2 tb2
            on  tb2.id  = tb1.id
            and exists
                (   select  0
                    from    table_2 sel
                    where   sel.id                  = tb2.id
                        and sel.ChangeDateTime      > tb1.ChangeDateTime
                    having  min(sel.ChangeDateTime) = tb2.ChangeDateTime
                )
    ;
    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.

  4. #4
    Candidat au Club
    Homme Profil pro
    Responsable de service informatique
    Inscrit en
    mai 2021
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Responsable de service informatique
    Secteur : Bâtiment

    Informations forums :
    Inscription : mai 2021
    Messages : 3
    Points : 2
    Points
    2
    Par défaut
    Bonjour

    tout d'abord, merci de vos réponses.

    Est-ce une seule et même table ou y en a-t-il deux distinctes ?
    Quelle est votre version de SQL-Server ?
    Oui je n'ai effectivement qu'une seule et même table avec un champ discriminatoire pour obtenir l'état (Enum_transition).


    Concernant le out de code de "Waldar", ta requête à l'air de fonctionner. J'ai juste changé le "inner join" par un "right join" pour tenir compte de tous les évènements d'activation.

    Je vérifie les résultats et je te tiens au courant.


    Cordialement

  5. #5
    Rédacteur
    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    mai 2002
    Messages
    20 774
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : mai 2002
    Messages : 20 774
    Points : 49 208
    Points
    49 208
    Billets dans le blog
    1
    Par défaut
    jamais vu des id aussi délirants ! Bonjour, les performances.... Bon passons.

    Il suffit d'utiliser la fonction LEAD ou LAG

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  6. #6
    Candidat au Club
    Homme Profil pro
    Responsable de service informatique
    Inscrit en
    mai 2021
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Responsable de service informatique
    Secteur : Bâtiment

    Informations forums :
    Inscription : mai 2021
    Messages : 3
    Points : 2
    Points
    2
    Par défaut
    Citation Envoyé par al1_24 Voir le message
    Quelque chose dans ce goût là (à vérifier)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    select  tb1.*
        ,   tb2.*
    from    table_1 tb1
        inner join
            table_2 tb2
            on  tb2.id  = tb1.id
            and exists
                (   select  0
                    from    table_2 sel
                    where   sel.id                  = tb2.id
                        and sel.ChangeDateTime      > tb1.ChangeDateTime
                    having  min(sel.ChangeDateTime) = tb2.ChangeDateTime
                )
    ;
    Impeccable le code marche. Merci beaucoup. tu m'enlève une bonne épine du pied.

  7. #7
    Modérateur

    Homme Profil pro
    Consultant Teradata
    Inscrit en
    septembre 2008
    Messages
    8 133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Consultant Teradata

    Informations forums :
    Inscription : septembre 2008
    Messages : 8 133
    Points : 16 376
    Points
    16 376
    Par défaut
    Plus simple si votre version de SQL-Server le supporte :
    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
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    declare @MaTable table (id varchar(10), ts datetime2, status tinyint);
     
    insert into @MaTable values
    ('INS025067', '2021-03-12 03:12:53.000', 8),
    ('INS025067', '2021-03-12 15:19:24.000', 5),
    ('INS023857', '2021-02-10 17:31:45.000', 8),
    ('INS023857', '2021-02-10 17:31:12.000', 8),
    ('INS023857', '2021-02-11 17:40:20.000', 2),
    ('INS023857', '2021-02-10 17:31:34.000', 6);
     
    with cte_lead as
    (
    select id, ts, status
         , case when lead(status) over(partition by id order by ts asc) < 8 then lead(ts)     over(partition by id order by ts asc) end as ts_end
         , case when lead(status) over(partition by id order by ts asc) < 8 then lead(status) over(partition by id order by ts asc) end as status_end
      from @MaTable
    )
    select *
      from cte_lead
     where status = 8;
     
    id         ts                           status  ts_end                       status_end
    ---------  ---------------------------  ------  ---------------------------  ----------
    INS023857  2021-02-10 17:31:12.0000000       8  2021-02-10 17:31:34.0000000           6
    INS023857  2021-02-10 17:31:45.0000000       8  2021-02-11 17:40:20.0000000           2
    INS025067  2021-03-12 03:12:53.0000000       8  2021-03-12 15:19:24.0000000           5

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

Discussions similaires

  1. Problème avec les jointures et between sur date
    Par krizenn dans le forum Langage SQL
    Réponses: 14
    Dernier message: 10/06/2016, 13h40
  2. Jointure sur date avec valeur null possible
    Par Wazzouille dans le forum Développement de jobs
    Réponses: 2
    Dernier message: 06/04/2016, 16h28
  3. jointures sur des dates et invites dans l'univers
    Par stamia dans le forum Designer
    Réponses: 1
    Dernier message: 27/05/2011, 16h50
  4. [Vxi] Auto-jointure sur max date
    Par Burt67 dans le forum Designer
    Réponses: 2
    Dernier message: 02/02/2011, 16h52
  5. Jointure sur date et max
    Par dirty_harry dans le forum SQL
    Réponses: 7
    Dernier message: 05/02/2010, 13h54

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