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

MS SQL Server Discussion :

Croiser deux intervalles de date et des données différentes


Sujet :

MS SQL Server

  1. #1
    Membre éprouvé
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Mai 2003
    Messages
    84
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2003
    Messages : 84
    Par défaut Croiser deux intervalles de date et des données différentes
    Bonjour à tous,

    Je souhaiterais croiser le contenu de deux tables gérant chacune des intervalles et je galère un peu.

    J'ai deux tables selon l'exemple suivant :
    T1 :
    id | Bureau | Date d'effet
    01| 401 | 01/01/2010
    01| 501 | 01/06/2010
    01| 502 | 01/01/2011


    T2 :
    id | Id CHEF | Date d'effet
    01| 44 | 01/01/2010
    01| 55 | 01/01/2012


    Et je voudrais croiser ces deux tables pour obtenir le résultat suivant :
    id | Bureau | Id CHEF | Date d'effet
    01| 401 | 44 | 01/01/2010
    01| 501 | 44 | 01/06/2010
    01| 502 | 44 | 01/01/2011
    01| 502 | 55 | 01/01/2012


    Je ne vois pas du tout comment aborder la question.
    Auriez-vous des idées ?

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 998
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

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

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 998
    Billets dans le blog
    6
    Par défaut
    Il faut commencer par faire une vue de chacun des tables pour ajouter la date finale des périodes calculées sur le fait que la fin d'une périodes est :
    • la période la plus récente de toutes les dates supérieures pour le même item
    • à défaut une date très loin dans le futur (31/12/9999)

    Il ne vous reste plus ensuite qu'à faire des thêta jointures avec le prédicat OVERLAPS dont voici une formulation : http://blog.developpez.com/sqlpro/p9...chement_d_inte

    Au passage merci de respecter la charte de postage : http://www.developpez.net/forums/d96...vement-poster/

    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/ * * * * *

  3. #3
    Membre éprouvé
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Mai 2003
    Messages
    84
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2003
    Messages : 84
    Par défaut
    La création de vues m'a permis de résoudre le problème.

    Merci

  4. #4
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    N'hésitez pas à poster votre solution afin qu'elle serve à d'autres !

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

Discussions similaires

  1. [AC-2003] A partir d'un intervalle de date remplir des données jour par jour
    Par colline_ dans le forum Access
    Réponses: 8
    Dernier message: 18/04/2014, 11h42
  2. calcul d'une date à partir des données de textbox
    Par jffaber dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 18/06/2008, 10h24
  3. Recuperation date insertion des données
    Par missd12 dans le forum Access
    Réponses: 4
    Dernier message: 16/06/2008, 12h35
  4. Réponses: 1
    Dernier message: 09/04/2008, 22h27
  5. [Dates] Afficher des données à la date du jour
    Par rastatom dans le forum Langage
    Réponses: 10
    Dernier message: 18/05/2006, 11h37

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