Acest tutorial arata cum puteti calcula numarul de zile dintre doua date, si cum sa obtineti zilele dintr-o anumita saptamana din an, in PHP si MySQL.

Calculare numar zile dintre doua date

• Ca sa obtineti numarul de zile dintre doua date in PHP, puteti folosi acest model:
<?php
// calculeaza numar de zile dintre $enddate si $startdate
$startdate = '2012-04-3';
$enddate = '2012-05-18';        // pt data curenta:  date('Y-m-d');
$days = (strtotime($enddate) - strtotime($startdate)) / (60 * 60 * 24);

echo $days;     // 45
?>

Daca vreti sa calculati numarul de zile dintre o anumita data si ziua curenta, folositi:   $enddate = date('Y-m-d');

- Pentru a selecta inregistrarile dintre doua date intr-o baza de date MySQL, puteti folosi acest model:
SELECT * FROM `table` WHERE `date` BETWEEN '2012-04-03' AND '2012-05-18'

- Pentru a selecta randurile dintre o anumita data si ziua curenta, folositi acest exemplu:
SELECT * FROM `table` WHERE `date` BETWEEN '2012-04-03' AND CURRENT_DATE

Obtinere zile dintr-o anumita saptamana din an

• Ca sa obtineti in PHP zilele dintr-o saptamana specificata dintr-un an, de luni pana duminica inclusiv (sau incepand cu oricare zi a saptamanii), puteti folosi aceasta functie:
// functie pt obtinere zile dintr-o saptamana ( marplo.net )
// returneaza un array cu zilele din $week_nr din $year
// $week_nr reprezinta numarul saptamanii din an
// initial, $startday e setat 1 (0=Duminica, 1=Luni, 2=Marti, ...)
function daysWeek($week_nr, $year, $startday=1) {
  $setweek = $week_nr;
  $re = array();      // retine rezultatul ce va fi returnat

  // parcurge numarul de zile dintr-o saptamana, 7
  for($i=0; $i<7; $i++){
    // seteaza numar zi din saptamana in functie de $startday
    $setday = $startday + $i;

    // daca $setday e 7 sau mai mare, scade 7 zile si mareste $setweek cu o saptamana
    if($setday >= 7) {
      $setday -= 7;
      $setweek = $week_nr + 1;
    }

    // adauga numarul zilei in $re
    $re[] = date('d', strtotime($year.'W'.$setweek.$setday));
  }

  return $re;
}

Al treilea parametru, $startday, seteaza ziua de inceput din saptamana, initial e 1 (pt zilele de Luni pana Duminica inclusiv), este optional.
Daca vreti sa obtineti zilele incepand cu alta zi din saptamana (alta decat Luni), adaugati la apelarea functiei daysWeek() un al treilea argument cu numarul zilei de inceput, 0 = Duminica, 1 = Luni, 2 = Marti, 3 = Miercuri, ..., sau date('N') pt ziua curenta.
- Exemple:
$days = daysWeek(20, 2011);     // zilele din saptamana 20 din 2011 (de Luni pana Luni)
$days = daysWeek(42, 2012, 0);     // zilele din saptamana 42 din 2012 (de Duminica pana Duminica)
$days = daysWeek(date('W')+1, date('Y'));     // zilele din saptamana urmatoare, din anul curent

Exemplu, obtine zilele din saptamana precedenta diin anul curent (incepand cu Luni):
<?php
// functie pt obtinere zile dintr-o saptamana ( marplo.net )
// returneaza un array cu zilele din $week_nr din $year
// $week_nr reprezinta numarul saptamanii din an
// initial, $startday e setat 1 (0=Duminica, 1=Luni, 2=Marti, ...)
function daysWeek($week_nr, $year, $startday=1) {
  $setweek = $week_nr;
  $re = array();      // retine rezultatul ce va fi returnat

  // parcurge numarul de zile dintr-o saptamana, 7
  for($i=0; $i<7; $i++){
    // seteaza numar zi din saptamana in functie de $startday
    $setday = $startday + $i;

    // daca $setday e 7 sau mai mare, scade 7 zile si mareste $setweek cu o saptamana
    if($setday >= 7) {
      $setday -= 7;
      $setweek = $week_nr + 1;
    }

    // adauga numarul zilei in $re
    $re[] = date('d', strtotime($year.'W'.$setweek.$setday));
  }

  return $re;
}

$week_nr = date('W') - 1;      // numarul saptamanii precedente
$year = date('Y');             // anul curent

// obtine zilele din saptamana precedenta (de Luni pana Duminica inclusiv)
$days = daysWeek($week_nr, $year);

// Test
var_export($days);
?>

- Pentru a selecta inregistrarile dintr-o anumita saptamana din an, dintr-o baza de date MySQL, puteti folosi acest exemplu:
SELECT * FROM `table` WHERE YEAR(`date`) = 2012 WEEK(`date`) = 40

- Pentru a selecta inregistrarile din saptamana precedenta, folositi aceasta interogare SQL:
SELECT * FROM `table` WHERE `date` BETWEEN DATE_SUB(CURDATE(), INTERVAL 1 WEEK) AND CURDATE()

Un Test simplu in fiecare zi

HTML
CSS
JavaScript
PHP-MySQL
Engleza
Spaniola
Ce atribut indica faptul ca un camp de formular trebuie completat?
required="required" autofocus="autofocus" placeholder="text"
<input type="text" name="name1" required="required" />
Ce metoda CSS misoreaza sau mareste dimensiunile unui element (inclusiv continutul)?
translate() scale() skew()
#some_id:hover {
  transform: scale(2, 1.5);
  -ms-transform: scale(2, 1.5);    /* IE 9 */
  -moz-transform: scale(2, 1.5);   /* Firefox */
}
Click pe metoda obiectului Date care returneaza ziua din luna.
setDate() getMonth() getDate()
var rightnow = new Date();
var day = rightnow.getDate();
alert(day);
Ce functie este folosita pentru a incarca un fisier pe server?
is_file() move_uploaded_file() fopen()
if(move_uploaded_file($_FILES["field_name"]["tmp_name"], "dir/file_name")) {
  echo "Fisierul a fost incarcat";
}
Cum se spune in engleza expresia: "Ploua cu galeata"?
rain cats and dogs rain buckets quiet rain
In Bucharest it`s raining cats and dogs.
- In Bucuresti ploua cu galeata.
Cum se spune in spaniola expresia: "Ploua cu galeata"?
llover cubo llover a cántaros lluvia tranquila
En Madrid está lloviendo a cántaros.
- In Madrid ploua cu galeata.
Numar Zile dintre doua date, zile din saptamana specificata

Last accessed pages

  1. Curs CSS Online Tutoriale CSS3 (7240)
  2. Exercitii engleza - English Tests and exercises - Grammar (32018)
  3. Curs si Tutoriale Ajax (3751)
  4. Cursuri limba engleza gratuite si lectii online (28697)
  5. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (69945)

Popular pages this month

  1. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (2264)
  2. Curs HTML gratuit Tutoriale HTML5 (1630)
  3. Curs si Tutoriale JavaScript (1598)
  4. Curs PHP MySQL, Tutoriale si Scripturi PHP (1550)
  5. Curs CSS Online Tutoriale CSS3 (1429)