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 :

comparer une date avaec celle de la ligne précédente


Sujet :

Développement SQL Server

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    490
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 490
    Points : 201
    Points
    201
    Par défaut comparer une date avaec celle de la ligne précédente
    Bonjour,

    J'ai une table visite (idvis, datevis)

    Je veux vérifier que ma date de visite est > à la date de la visite précédente. Mais je ne vois pas du tout comment faire

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    Idvis | datevis |
    ----------------
    1      | 20/01/2010
    2      | 15/02/2010
    3      | 12/03/2010
    4      | 10/03/2010
    Ce que je veux c'est faire ressortir la visite ...
    Une petite idée ?

    merci

  2. #2
    Membre expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Points : 3 173
    Points
    3 173
    Par défaut
    De manière triviale:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SELECT idvis,datevis
    FROM dbo.visite V1
    WHERE datevis>(SELECT datevis FROM dbo.visite V2
                           WHERE V2.idvis=V1.idvis-1)
    ou

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT idvis,datevis,(SELECT datevis FROM dbo.visite V2
                           WHERE V2.idvis=V1.idvis-1)as LastDateVis
    FROM dbo.visite V1
    Avec un OUTER APPLY également...

  3. #3
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Bonjour,

    se baser sur les ID pour définir l'ordre n'est pas une bonne chose. dans tous les cas, pensez que vous pouvez avoir des "trou" dans cette séquence, par exemple dans le cas d'une insertion qui viole une contrainte. idéalement, il faudrait une colonne "ordre"

    mais vous pouvez faire ainsi :

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    WITH V AS (
        SELECT Idvis, datevis, ROW_NUMBER() OVER (ORDER BY Idvis) AS RN
        FROM visite
    )
    SELECT V1.idvis, V1.datevis, V2.idvis AS idvis_suivante, V2.datevis AS datevis_suivante
    FROM V V1
    LEFT OUTER JOIN V V2
        ON V2.RN = V1.RN + 1
    WHERE V1.datevis > V2.datevis


    Si vous voulez eviter la fonction de fenetrage, vous pouvez aussi faire ainsi :
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    SELECT V1.idvis, V1.datevis, V2.idvis AS idvis_suivante, V2.datevis AS datevis_suivante
    FROM Visite V1
    OUTER APPLY (
        SELECT TOP(1) idvis, datevis
        FROM visite
        WHERE idvis > V1.idvis
        ORDER BY idvis
    ) V2
    WHERE V1.datevis > V2.datevis

  4. #4
    Membre actif
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    490
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 490
    Points : 201
    Points
    201
    Par défaut
    Merci à vous deux... c'est bien complexe tout de même...

  5. #5
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Points : 12 371
    Points
    12 371
    Par défaut
    Bonjour,

    C'est normal puisqu'en SQL il n'y a pas d'ordre ... ni dans les colonnes, ni dans les lignes.

    Rappelons que les tables sont une représentation des entités du MCD, lui même représentant des ensembles de données du monde réel.
    Un ensemble n'a pas d'ordre.

    @++

  6. #6
    Membre actif
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    490
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 490
    Points : 201
    Points
    201
    Par défaut
    oui... mais ça reste complexe ;-)

  7. #7
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Points : 12 371
    Points
    12 371
    Par défaut
    Non, c'est votre modèle qui n'est pas adapté à votre besoin

    @++

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

Discussions similaires

  1. Comparer une valeur à d'une date actuelle à celle d'une date antérieure
    Par kiwilicious dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 6
    Dernier message: 22/05/2014, 09h37
  2. Réponses: 3
    Dernier message: 31/01/2011, 18h26
  3. Réponses: 3
    Dernier message: 28/10/2009, 17h34
  4. [Dates] Comparer une date à celle du jour
    Par godjojo dans le forum Langage
    Réponses: 2
    Dernier message: 12/07/2007, 09h36
  5. [DB2] - Comparer une date à la date système
    Par rémi_tounul dans le forum DB2
    Réponses: 3
    Dernier message: 19/05/2005, 11h45

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