Comparer 2 dates d'echeances Transact SQL

Résolu/Fermé
goodspirit Messages postés 8 Date d'inscription jeudi 22 juillet 2010 Statut Membre Dernière intervention 4 août 2010 - Modifié par goodspirit le 23/07/2010 à 09:41
goodspirit Messages postés 8 Date d'inscription jeudi 22 juillet 2010 Statut Membre Dernière intervention 4 août 2010 - 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

A voir également:

3 réponses

goodspirit Messages postés 8 Date d'inscription jeudi 22 juillet 2010 Statut Membre Dernière intervention 4 août 2010
23 juil. 2010 à 11:48
Voici le Code que j'ai écrit mais il me donne pas les bons résultats :(

WITH T0 (IdEcheanceInteret , DtDebutPeriode, DtFinPeriode,N)
AS
(
SELECT IdEcheanceInteret +1 'id', DtDebutPeriode, DtFinPeriode
, ROW_NUMBER() OVER(ORDER BY DtDebutPeriode) AS N

FROM EcheanceInteret
)
SELECT *
FROM T0 AS T1
INNER JOIN T0 AS T2
ON T1.N = T2.N
WHERE T1.DtFinPeriode != T2.DtDebutPeriode


Est ce que quelqu'un a une idée comment je peux faire en Transact SQL
0
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.
0
goodspirit Messages postés 8 Date d'inscription jeudi 22 juillet 2010 Statut Membre Dernière intervention 4 août 2010
23 juil. 2010 à 15:14
Merci beaucoup pour ta réponse.
je l'ai essayé mais ça donne pas ce que je veux :(
0
C'est quoi le problème ?
0
goodspirit Messages postés 8 Date d'inscription jeudi 22 juillet 2010 Statut Membre Dernière intervention 4 août 2010
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 :(
0
Pourrais tu donner un petit exemple de ce que tu as en table et du résultat obtenu STP ?
Mon raisonnement me semble OK...
0
goodspirit Messages postés 8 Date d'inscription jeudi 22 juillet 2010 Statut Membre Dernière intervention 4 août 2010
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.
0
goodspirit Messages postés 8 Date d'inscription jeudi 22 juillet 2010 Statut Membre Dernière intervention 4 août 2010
4 août 2010 à 15:16
Merci pour tout.
J'ai trouvé la solution :)
0
HostOfSeraphim Messages postés 6750 Date d'inscription jeudi 2 février 2006 Statut Contributeur Dernière intervention 31 juillet 2016 1 607
4 août 2010 à 16:48
Qui est ?
0
goodspirit Messages postés 8 Date d'inscription jeudi 22 juillet 2010 Statut Membre Dernière intervention 4 août 2010
Modifié par goodspirit le 4/08/2010 à 17:14
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
0