Difference entre 2 date ??

[Résolu/Fermé]
Signaler
Messages postés
241
Date d'inscription
mardi 9 décembre 2003
Statut
Membre
Dernière intervention
17 mai 2012
-
 jfqld -
Slt !!!!
je cherche a savoir comment fait on pour faire la difference entre 2 date sous forme SQL, ....

merci...

11 réponses

Messages postés
33478
Date d'inscription
jeudi 14 octobre 2004
Statut
Modérateur
Dernière intervention
24 février 2011
1 783
mysql> SELECT DATEDIFF('1997-12-31 23:59:59','1997-12-30');
        -> 1
mysql> SELECT DATEDIFF('1997-11-30 23:59:59','1997-12-31');
        -> -31

DATEDIFF() was added in MySQL 4.1.1. 


Et de manière générale, tout bon moteur aurait put te donner:

http://tinyurl.com/4xb3j
19
Merci

Quelques mots de remerciements seront grandement appréciés. Ajouter un commentaire

CCM 41713 internautes nous ont dit merci ce mois-ci

Messages postés
32844
Date d'inscription
mercredi 29 août 2001
Statut
Modérateur
Dernière intervention
21 octobre 2019
15 601
ça dépend de ton serveur SQL.

Sous Microsoft SQL Server, c'est DATEDIFF()
Messages postés
33478
Date d'inscription
jeudi 14 octobre 2004
Statut
Modérateur
Dernière intervention
24 février 2011
1 783
Bon alors dans ton cas

SELECT division.nom_div, type_mat.id_sorte_mat, type_mat.designation, materiel.date_livraison, materiel.statut, count( * ) nbr_ucs
FROM materiel, division, type_mat
WHERE materiel.id_div = division.id_div
AND materiel.id_type_mat = type_mat.id_type_mat
AND type_mat.id_sorte_mat = 2
AND materiel.statut = "A"


AND DATE_SUB(DATE("01/01/1998"),INTERVAL DATEDIFF("26/01/2005","01/01/1998") DAY) <= materiel.date_livraison;
GROUP BY designation;


Ca devrait marcher, à l'ordre des dates près (si ça marche pas remplace 98 par 2005 dans le DATEDIFF) mais je suppose que tu préfereras:


AND DATE_SUB(DATE("01/01/1998"),INTERVAL DATEDIFF(;CURDATE(),"01/01/1998") DAY) <= materiel.date_livraison;
Messages postés
33478
Date d'inscription
jeudi 14 octobre 2004
Statut
Modérateur
Dernière intervention
24 février 2011
1 783
critique accepter
critique acceptée :-D Trop tentant ça ;o)
Le problème est que 01/01/1998 est compris comme une string, qui plus est DIFF est une fonction je crois, essaye donc DIFF(DATE("date"), DATE("date2")) ou un truc du genre...mais seb à raison :o)
Messages postés
241
Date d'inscription
mardi 9 décembre 2003
Statut
Membre
Dernière intervention
17 mai 2012
38
je suis sous mysql esque cela pourait fonctioner sous MYSQL?...
sinon comment kon fait...

les fonctions ci dessous, je n'est jamais utiliser de fonction de ce genre....chi pô mai vé tester ku meme, rien a perdre hihihi que du temp mé bont
voila mon code je cherche a savoir ce qui ne va pas
aidez moi, .S.V.P
Fonction de calcul de la duree.

$dd=date debut in terne à la fonction
$df=date fin interne à la fonction
$td=heure debut interne à la fonction
$tf=heure de fin interne à la fonction
$jd=jour debut
$md=mois debut
$ad=annee debut
$jf=jour fin
$mf=mois fin
$af=annee fin


<?php function temps_ecoule($date_debut,$date_fin)
{
If($date_debut)= =’ ’{ $resultat=’’ impossible de démarrer la fonction ‘’ ;

}else{ if date_fin ! =’ ‘{

List($dd,$td)=explode(‘/ ’,$dd); // separation date et heure debut

List($df,$tf)=explode(‘/ ’,$df); // separation date et heure fin

List($jd,$md,$ad)=explode(‘/ ’,$dd); // explosion date debut

$pd=mktime (0,0,0,$md,$jd,$ad); // structure de date debut

List($hd,$mid,$sd)=explode(‘:’,$td); // explosion heure debut

List($jf,$mf,$af)=explode(‘/’,$df); // separation date et heure debut

$pf=mktime (0,0,0,$mf,$jf,$af); // structure de date fin


List($hf,$mif,$sf)=explode(‘:’,$tf); // explosion heure fin

$tsf =mktime($hd,$mid,$sd,1,1,1970) ; // structure heure debut

$tsf=mktime($hf,$mif,$sf,1,1,1970) ; // structure heure fin

$ts=abs($tsf- $tsf);

$resultat =$ts;
Return $resultat;

?>



<form>

<p> date heure début </p>
<p> debut<input type =‘’texte’’,name=’’debut’’></p>
<p> fin<input type =‘’texte’’,name=’’fin’’></p>
<p> duree<input type =‘’texte’’,name=’’duree’’ onclik=’’temps_ecoule’’></p>

</form>
voila mon code je cherche a savoir ce qui ne va pas
aidez moi, .S.V.P
Fonction de calcul de la duree.

$dd=date debut in terne à la fonction
$df=date fin interne à la fonction
$td=heure debut interne à la fonction
$tf=heure de fin interne à la fonction
$jd=jour debut
$md=mois debut
$ad=annee debut
$jf=jour fin
$mf=mois fin
$af=annee fin


<?php function temps_ecoule($date_debut,$date_fin)
{
If($date_debut)= =’ ’{ $resultat=’’ impossible de démarrer la fonction ‘’ ;

}else{ if date_fin ! =’ ‘{

List($dd,$td)=explode(‘/ ’,$dd); // separation date et heure debut

List($df,$tf)=explode(‘/ ’,$df); // separation date et heure fin

List($jd,$md,$ad)=explode(‘/ ’,$dd); // explosion date debut

$pd=mktime (0,0,0,$md,$jd,$ad); // structure de date debut

List($hd,$mid,$sd)=explode(‘:’,$td); // explosion heure debut

List($jf,$mf,$af)=explode(‘/’,$df); // separation date et heure debut

$pf=mktime (0,0,0,$mf,$jf,$af); // structure de date fin


List($hf,$mif,$sf)=explode(‘:’,$tf); // explosion heure fin

$tsf =mktime($hd,$mid,$sd,1,1,1970) ; // structure heure debut

$tsf=mktime($hf,$mif,$sf,1,1,1970) ; // structure heure fin

$ts=abs($tsf- $tsf);

$resultat =$ts;
Return $resultat;

?>



<form>

<p> date heure début </p>
<p> debut<input type =‘’texte’’,name=’’debut’’></p>
<p> fin<input type =‘’texte’’,name=’’fin’’></p>
<p> duree<input type =‘’texte’’,name=’’duree’’ onclik=’’temps_ecoule’’></p>

</form>
Messages postés
33478
Date d'inscription
jeudi 14 octobre 2004
Statut
Modérateur
Dernière intervention
24 février 2011
1 783
Salut,
Je crois que c'est DIFF...
Messages postés
241
Date d'inscription
mardi 9 décembre 2003
Statut
Membre
Dernière intervention
17 mai 2012
38
salut!

en fait j'ai tester ! mais je ne c'est pas si c'est ma requête ou si c'est la methode DIFF qui fonctionne pas voici ma reqête voici!!!
critique accepter :)

SELECT division.nom_div, type_mat.id_sorte_mat, type_mat.designation, materiel.date_livraison, materiel.statut, count( * ) nbr_ucs
FROM materiel, division, type_mat
WHERE materiel.id_div = division.id_div
AND materiel.id_type_mat = type_mat.id_type_mat
AND type_mat.id_sorte_mat = 2
AND materiel.statut = "A"


AND materiel.date_livraison= "01/01/1998" DIFF "26/01/2005"
GROUP BY designation;

si c du oracle
c'est juste le signe - ; ca donne le nombre de jours,sinon il y a MONTHS_BETWEEN(date1,date2)
...
Messages postés
33478
Date d'inscription
jeudi 14 octobre 2004
Statut
Modérateur
Dernière intervention
24 février 2011
1 783
C'est du MySql :o)
Messages postés
241
Date d'inscription
mardi 9 décembre 2003
Statut
Membre
Dernière intervention
17 mai 2012
38
slt ! effectivement c'est du Mysql, j'ai tester mais cela fait encore des erreurs,je ne c'est pas si c'est la methode oubin moi... je veut essayer d'ecrire le prog en php, mais je n'en connait pas plus que sql, esque c'est la meme chose ? on ma dit qu'il faut utiliser des conditions ?...

merci de m'apporter quelques renseignements à ce sujet..
a+
Salut,
La solution la plus simple pour comparer deux dates est de les convertir en format timestamp avec la fonction maketime() puis de comparer les deux timestamp.
Oh la désolé je viens de voir que c'etait juste du MySql
J'etais parti en php :))
Bjr,
Je dois comparer entre deux dates date_Début et date_Fin il faut que la difference = 15jours et Je n'ai aucune idée comment ca s'écrit sur SQL SERVER 2005 es ce que quelqu'un peut m'aider SVP
=SUPPRESPACE(SI(AUJOURDHUI()-D;TEXTE(DATEDIF(D;AUJOURDHUI();"y");"[>1]0"" ans"";
[>]""1 an"";")&TEXTE(DATEDIF(D;AUJOURDHUI();"ym");"[>] 0"" mois "";")&
TEXTE(DATEDIF(D;AUJOURDHUI();"md");"[>1]0"" jours"";[>]""1 jour"";");"0 jour"))
essaie cette formule