Pereiti prie turinio

Darbas su laiko skirtumu tarp dviejų datų. (PHP ir MySQL)


Rekomenduojami pranešimai

Neretai turbūt teko susidurti su problema, kai reikėdavo apskaičiuoti laiko skirtuma tarp dviejų datų. Šis variantas labai paprastas ir naudingas.

 

// nurodome dvi datas mktime funkcijoje.
//sintakse yra mktime(valandos,minutes,sekundes,menuo,diena,metai);
$data1=mktime(12,15,0,7,10,2010);
$data2=mktime(17,22,0,7,11,2010);

echo "Valandų skirtumas = ".floor(($data2-$data1)/3600) . "<br>";
echo "Minučių skirtumas = ".floor(($data2-$data1)/60) . "<br>";
echo "Sekundžių skirtumas = " .($data2-$data1). "<br>";


echo "Menesių skirtumas = ".floor(($data2-$data1)/2628000) . "<br>";
echo "Dienų skirtumas = ".floor(($data2-$data1)/86400) . "<br>";
echo "Metų skirtumas = ".floor(($data2-$data1)/31536000) . "<br>";

 

 

 

Kitas variantas yra skirtas gauti laiko skirtumą tarp 2 laiko vienetų tiesiai MySQL užklausoje.

Pvz:

 

$laikas = mysql_query("SELECT TIMESTAMPDIFF(HOUR, nuo, iki) AS skirtumas FROM lentele");

// Sukuriamas naujas stulpelis pavadinimu 'skirtumas'
// rodantis datos skirtumą valandų tikslumu.
// Taip pat galima skirtuma isgauti SECOND MINUTE, DAY, WEEK, MONTH, YEAR

 

Tikiuosi kam nors pravers.

Redagavo amzinas
Nuoroda į pranešimą
Dalintis kituose puslapiuose
  • Administratoriai

šiek tiek praleodai, turi būti:

echo "Minučių skirtumas = ".floor(($data2-$data1)/60) . "

";

 

 

čia dar padariau tokį grubų pavyzdį "kiek man metų" pagal tavo skriptą

 

function kiekManMetu($metai,$menuo,$diena){
return round((mktime(17,22,0,date('n'),date('j'),date('Y'))-mktime(12,15,0,$menuo,$diena,$metai))/31536000, 1);
}

echo "Mano amžius: ".kiekManMetu('1980','1','1')." m.<br />";
echo "Lietuva laisva jau ".kiekManMetu('1990','3','11')." m.<br />";

Redagavo Arius
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Prisijunkite prie diskusijos

Jūs galite rašyti dabar, o registruotis vėliau. Jeigu turite paskyrą, prisijunkite dabar, kad rašytumėte iš savo paskyros.

Svečias
Parašykite atsakymą...

×   Įdėta kaip raiškusis tekstas.   Atkurti formatavimą

  Only 75 emoji are allowed.

×   Nuorodos turinys įdėtas automatiškai.   Rodyti kaip įprastą nuorodą

×   Jūsų anksčiau įrašytas turinys buvo atkurtas.   Išvalyti redaktorių

×   You cannot paste images directly. Upload or insert images from URL.

Įkraunama...
  • Dabar naršo   0 narių

    Nei vienas registruotas narys šiuo metu nežiūri šio puslapio.

  • Prisijunk prie bendruomenės dabar!

    Uždarbis.lt nariai domisi verslo, IT ir asmeninio tobulėjimo temomis, kartu sprendžia problemas, dalinasi žiniomis ir idėjomis, sutinka būsimus verslo partnerius ir dalyvauja gyvuose susitikimuose.

    Užsiregistruok dabar ir galėsi:

    ✔️ Dalyvauti diskusijose;

    ✔️ Kurti naujas temas;

    ✔️ Rašyti atsakymus;

    ✔️ Vertinti kitų žmonių pranešimus;

    ✔️ Susisiekti su bet kuriuo nariu asmeniškai;

    ✔️ Naudotis tamsia dizaino versija;

    ir dar daugiau.

    Registracija trunka ~30 sek. ir yra visiškai nemokama.

  • Naujausios temos

  • Karštos temos

×
×
  • Pasirinkite naujai kuriamo turinio tipą...