Как вычесть/добавить интервалы в годы/месяц к дате (например, интервальное выражение MySQL)Php

Кемеровские программисты php общаются здесь
Ответить
Anonymous
 Как вычесть/добавить интервалы в годы/месяц к дате (например, интервальное выражение MySQL)

Сообщение Anonymous »

Предположим, мне нужно изменить объект datetime, добавив или вычитая несколько месяцев.
Как избежать хорошо известных вычислений месяца в PHP?
$monthstoadd=-1;
//today is 2025-01-24

$date=new DateTime("last day of last month");

echo $date->format('Y-m-d');
//out: is 2024-12-31

$date->modify(($monthstoadd>0?'+':'').$monthstoadd.' month');

echo $date->format('Y-m-d');
//out: is 2024-12-01

Начиная с последнего дня месяца, я ожидаю всегда получать последний день месяца (минимальный уровень).
Есть ли способ изменить дату с этим предпочтением?
Вот как работает SQLite:
SELECT date('2025-01-30', '+1 month')
-> '2025-03-02'
< /code>
Вот как работает MySQL: < /p>
SELECT '2025-01-30' + interval 1 month
-> '2025-02-28'


Подробнее здесь: https://stackoverflow.com/questions/793 ... al-express
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Php»