Rechercher : dans
Par :

Difference entre 2 date ??

Dernière réponse le 10 jui 2008 à 13:17:55 trik59, le 26 jan 2005 à 14:20:57 
 Signaler ce message aux modérateurs

Slt !!!!
je cherche a savoir comment fait on pour faire la difference entre 2 date sous forme SQL, ....

merci...

1

teebo, le 26 jan 2005 à 14:26:49
  • +1

Salut,
Je crois que c'est DIFF...
Qui va en mer pour son plaisir,
irait en enfer pour ses vacances

Répondre à teebo

2

trik59, le 26 jan 2005 à 14:33:57

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;

Répondre à trik59

3

sebsauvage, le 26 jan 2005 à 14:34:44

Ça dépend de ton serveur SQL.

Sous Microsoft SQL Server, c'est DATEDIFF()

Répondre à sebsauvage

4

teebo, le 26 jan 2005 à 14:37:41
  • +1

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)
Qui va en mer pour son plaisir,
irait en enfer pour ses vacances

Répondre à teebo

5

trik59, le 26 jan 2005 à 14:41:43
  • +1

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

Répondre à trik59

6

teebo, le 26 jan 2005 à 14:57:41
  • +6

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
Qui va en mer pour son plaisir,
irait en enfer pour ses vacances

Répondre à teebo

7

teebo, le 26 jan 2005 à 16:27:21
  • +1

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; Qui va en mer pour son plaisir,
irait en enfer pour ses vacances

Répondre à teebo

8

Dupont avec un u, le 27 jan 2005 à 10:35:43
  • +1

Si c du oracle
c'est juste le signe - ; ca donne le nombre de jours,sinon il y a MONTHS_BETWEEN(date1,date2)
...

Répondre à Dupont avec un u

9

teebo, le 27 jan 2005 à 10:40:38

C'est du MySql :o)
Qui va en mer pour son plaisir,
irait en enfer pour ses vacances

Répondre à teebo

10

trik59, le 27 jan 2005 à 10:49:16

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+

Répondre à trik59

11

Dja, le 27 jan 2005 à 15:08:36
  • +1

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.

Répondre à Dja

12

Dja, le 27 jan 2005 à 15:11:11

Oh la désolé je viens de voir que c'etait juste du MySql
J'etais parti en php :))

Répondre à Dja

13

alain, le 3 jun 2008 à 20:30:37

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>

Répondre à alain

14

ogboalain, le 5 jun 2008 à 22:25:06

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>

Répondre à ogboalain

15

Krech, le 4 jui 2008 à 16:40:36

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

Répondre à Krech

16

 jfqld, le 10 jui 2008 à 13:17:55

=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

Répondre à jfqld