Classe DateTimeImmutable
A classe DateTimeImmutable é uma contraparte imutável da DateTime. Ela cria um novo objeto a cada modificação, tornando-o mais previsível e seguro para trabalhar.
Momento atual
Vamos criar um objeto DateTimeImmutable
com a data e hora atuais:
<?php
$date = new DateTimeImmutable();
?>
Data específica
Vamos criar um objeto DateTimeImmutable com uma data especificada:
<?php
$date = new DateTimeImmutable('2025-12-31');
?>
Data e hora específicas
Vamos criar um objeto DateTimeImmutable
com uma data e hora especificadas:
<?php
$date = new DateTimeImmutable('2025-12-31 12:59:59');
?>
Formatação de saída
A data criada pode ser exibida em um formato específico
usando o método format. Vamos fazer
isso para o momento atual:
<?php
$date = new DateTimeImmutable();
echo $date->format('Y-m-d H:i:s');
?>
Resultado (irá variar dependendo do momento de execução):
'2025-11-15 14:25:00'
Formatação de data especificada
Vamos formatar uma data especificada:
<?php
$date = new DateTimeImmutable('2025-12-31');
echo $date->format('d.m.Y');
?>
Resultado da execução do código:
'31.12.2025'
Adicionando um intervalo
A adição de um intervalo a uma data
é feita através do método add:
<?php
$date = new DateTimeImmutable('2025-05-15');
$interval = new DateInterval('P10D'); // 10 dias
$newDate = $date->add($interval);
echo $newDate->format('Y-m-d');
?>
Resultado da execução do código:
'2025-05-25'
Subtraindo um intervalo
A subtração de um intervalo de uma data
é feita através do método sub:
<?php
$date = new DateTimeImmutable('2025-05-15');
$interval = new DateInterval('P1M2D'); // 1 mês e 2 dias
$newDate = $date->sub($interval);
echo $newDate->format('Y-m-d');
?>
Resultado da execução do código:
'2025-04-13'
Definindo uma nova data
É possível definir uma nova data para
o objeto DateTimeImmutable. Isso é feito
através do método setDate:
<?php
$date = new DateTimeImmutable();
$newDate = $date->setDate(2024, 12, 31);
echo $newDate->format('Y-m-d');
?>
Resultado da execução do código:
'2024-12-31'
Definindo o horário
É possível definir um novo horário para
o objeto DateTimeImmutable. Isso é feito
através do método setTime:
<?php
$date = new DateTimeImmutable();
$newDate = $date->setTime(15, 30, 0);
echo $newDate->format('H:i:s');
?>
Resultado da execução do código:
'15:30:00'
Comparando datas
É possível comparar objetos de data:
<?php
$date1 = new DateTimeImmutable('2025-01-01');
$date2 = new DateTimeImmutable('2025-02-01');
if ($date1 < $date2) {
echo '+++';
} else {
echo '---';
}
?>
Criando objeto com fuso horário
Ao criar um objeto DateTimeImmutable
é possível especificar um fuso horário:
<?php
$timeZone = new DateTimeZone('Europe/Moscow');
$date = new DateTimeImmutable('2025-12-31 23:59:59', $timeZone);
echo $date->format('Y-m-d H:i:s e');
?>
Resultado da execução do código:
'2025-12-31 23:59:59 Europe/Moscow'
Veja também
-
classe
DateInterval,
que define um intervalo de tempo -
classe
DateTimeZone,
que define um fuso horário