DateTime::sub
date_sub
(PHP 5 >= 5.3.0)
DateTime::sub -- date_sub — Sustrae una cantidad de días, meses, años, horas, minutos y segundos de un objeto DateTime
Descripción
Estilo orientado a objetos
Estilo por procedimientos
Sustrae el objeto DateInterval especificado del objeto DateTime especificado.
Parámetros
-
object -
Solamente para el estilo por procedimientos: Un objeto DateTime devuelto por date_create(). La función modifica este objeto.
-
interval -
Un objeto DateInterval
Valores devueltos
Devuelve el objeto DateTime para la cadena de métodos o FALSE en caso de error.
Ejemplos
Ejemplo #1 Ejemplo de DateTime::sub()
Estilo orientado a objetos
<?php
$fecha = new DateTime('2000-01-20');
$fecha->sub(new DateInterval('P10D'));
echo $fecha->format('Y-m-d') . "\n";
?>
Estilo por procedimientos
<?php
$fecha = date_create('2000-01-20');
date_sub($fecha, date_interval_create_from_date_string('10 days'));
echo date_format($fecha, 'Y-m-d');
?>
El resultado de los ejemplos serían:
2000-01-10
Ejemplo #2 Más ejemplos de DateTime::sub()
<?php
$fecha = new DateTime('2000-01-20');
$fecha->sub(new DateInterval('PT10H30S'));
echo $fecha->format('Y-m-d H:i:s') . "\n";
$fecha = new DateTime('2000-01-20');
$fecha->sub(new DateInterval('P7Y5M4DT4H3M2S'));
echo $fecha->format('Y-m-d H:i:s') . "\n";
?>
El resultado del ejemplo sería:
2000-01-19 13:59:30 1992-08-15 19:56:58
Ejemplo #3 Cuidado al sustraer meses
<?php
$fecha = new DateTime('2001-04-30');
$intervalo = new DateInterval('P1M');
$fecha->sub($intervalo);
echo $fecha->format('Y-m-d') . "\n";
$fecha->sub($intervalo);
echo $fecha->format('Y-m-d') . "\n";
?>
El resultado del ejemplo sería:
2001-03-30 2001-03-02
Notas
DateTime::modify() es una alternativa cuando se usa PHP 5.2.
Ver también
- DateTime::add() - Añade una cantidad de días, meses, años, horas, minutos y segundos a un objeto DateTime
- DateTime::diff() - Devuelve la diferencia entre dos objetos DateTime
- DateTime::modify() - Altera la marca temporal