Posez votre question Signaler

Comparer 2 dates d'echeances Transact SQL [Résolu]

goodspirit 3Messages postés 22 juillet 2010Date d'inscription 4 août 2010Dernière intervention - Dernière réponse le 4 août 2010 à 17:13
Bonjour,
Normalement, je travaille sur SQL Server, j'ai plusieurs tables d'echeances qui sont déjà créer et remplies.
je prends comme exemple une table EcheanceInteret qui a pour champs : IdEcheance, Date Début echenace, Date Fin echeance.....
exemple :
Id Date Début echeance Date Fin echeance
100 1989-03-31 00:00:00 1990-03-31 00:00:00
101 1990-03-31 00:00:00 1991-03-31 00:00:00
102 1991-03-31 00:00:00 1992-03-31 00:00:00
On m'a demandé de faire une requête qui vérifie que toutes les dates d'échéances doivent se suivre : Date de début échéance = date de fin de l'échéance précédente.
exemple: date début de l'echeance 101 = date fin d'echeance 100.
Alors dans ma requête je dois comparer la Date de début échéance avec la date de fin de l'échéance précédente. si ils sont égales c'est ce que je cherche, sinon je dois récupérer ces dates pour les corriger.
Est ce que quelqu'un peut m'aider SVP
Merci d'avance
Lire la suite 

Comparer 2 dates d'echeances Transact SQL »

10 réponses
Réponse
+0
moins plus
Bonjour,

Je pense que tu peux t'en sortir avec une requête assez simple, dans ce style :

-- sélectionner une échéance
SELECT * FROM ECHEANCE E_SUIV
-- qui a une échéance précédente
WHERE EXISTS ( SELECT 1 FROM ECHEANCE E_PREC WHERE E_PREC.IDECHEANCE = E_SUIV.IDECHEANCE - 1
-- mais que la date de fin de l'échéance précédente n'est pas celle de
-- début de la suivante
AND E_PREC.DATEFIN <> E_SUIV.DATEDEBUT
)

Avec ce genre de requête, tu devrais récupérer la liste des échéances qui ne suivent pas l'échéance précédente.

Qu'en penses-tu ? Ça correspond à ton besoin ?

Cordialement, M.
goodspirit- 23 juil. 2010 à 15:27
quand j'execute la requête, j'ai une table qui contient IdEcheance et les dates. alors quand je compare l'id avec son preced et son succes, je trouve que les dates sont bien il y a pas de prob.
il me sort pas les dates ou j'ai l'erreur :(
swed - 23 juil. 2010 à 15:29
Pourrais tu donner un petit exemple de ce que tu as en table et du résultat obtenu STP ?
Mon raisonnement me semble OK...
goodspirit- 23 juil. 2010 à 15:38
voici un exp :
dans ma table j'ai ça :
IdEcheance Date Debut Date Fin
100 2003-11-30 00:00:00.000 2004-12-01 00:00:00.000
101 2004-12-01 00:00:00.000 2005-12-01 00:00:00.000
102 2005-12-01 00:00:00.000 2006-12-01 00:00:00.000
103 2006-12-01 00:00:00.000 2007-12-01 00:00:00.000
104 2007-12-01 00:00:00.000 2008-12-01 00:00:00.000

et quand j'exécute ta requête il me sort
dEcheance Date Debut Date Fin
100 2003-11-30 00:00:00.000 2004-12-01 00:00:00.000
102 2005-12-01 00:00:00.000 2006-12-01 00:00:00.000
104 2007-12-01 00:00:00.000 2008-12-01 00:00:00.000

je ne sais pas pourquoi pour ça j'ai pas de prob mais je cherche les dates qui sont pas bonnes :(
je ne sais pas comment faire.
Ajouter un commentaire
Réponse
+0
moins plus
Merci pour tout.
J'ai trouvé la solution :)
HostOfSeraphim- 4 août 2010 à 16:48
Qui est ?
goodspirit- 4 août 2010 à 17:13
WITH date_test
AS
(
SELECT idEcheanceAmortissement , IdEmprunt, idAmortissement, DtDebutPeriode, DtFinPeriode
, ROW_NUMBER() OVER(ORDER BY idEmprunt,idAmortissement, DtDebutPeriode, DtFinPeriode) AS N
FROM EcheanceAmortissement
)
SELECT *
FROM date_test AS T1, date_test AS T2
WHERE T1.N + 1= T2.N
and T2.DtDebutPeriode <> T1.DtFinPeriode
and T1.idEmprunt = T2.idEmprunt
and T1.idAmortissement=T2.idAmortissement
order by T1.idEmprunt, T1.idAmortissement, T1.DtDebutPeriode, T1.DtFinPeriode
Ajouter un commentaire
Ce document intitulé « comparer 2 dates d'echeances Transact SQL » issu de CommentCaMarche (www.commentcamarche.net) est mis à disposition sous les termes de la licence Creative Commons. Vous pouvez copier, modifier des copies de cette page, dans les conditions fixées par la licence, tant que cette note apparaît clairement.
Dossier à la une
Passage au tout numérique : quel coût pour les particuliers ?