Как вычесть время из даты и времени

Я получаю поле enddatetime, которое создается автоматически. У меня также есть totaltime, который хранится в mysql. Я хочу вычесть enddatetime из totaltime, чтобы получить startdatetime и datetimeofevent.

Пример

totaltime = 14:00:00

enddatetime = 14.05.2018 15:00:00

В настоящее время я использую функцию date_sub, но она вычитает hh из yy, который носит.

DATE_SUB(enddatetime , INTERVAL (TimeDIFF(totaltime, Time(enddatetime ))) HOUR)
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
В последние годы архитектура микросервисов приобрела популярность как способ построения масштабируемых и гибких приложений. Laravel , популярный PHP...
Как построить CRUD-приложение в Laravel
Как построить CRUD-приложение в Laravel
Laravel - это популярный PHP-фреймворк, который позволяет быстро и легко создавать веб-приложения. Одной из наиболее распространенных задач в...
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
В предыдущем посте мы создали функциональность вставки и чтения для нашей динамической СУБД. В этом посте мы собираемся реализовать функции обновления...
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
Роли и разрешения пользователей без пакета Laravel 9
Роли и разрешения пользователей без пакета Laravel 9
Этот пост изначально был опубликован на techsolutionstuff.com .
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
В предыдущей статье мы завершили установку базы данных, для тех, кто не знает.
0
0
30
2

Ответы 2

Вам нужно извлечь часть времени из enddatetime из первой части date_sub

Я попробовал это сделать, но у меня ничего не вышло. У вас есть пример, как это должно работать

Zack 14.05.2018 17:20

Функция dateTimeDIFF возвращает разницу в формате времени, например 12:30:50 а также DATE_SUB ожидает, что интервал будет целым числом вам нужно преобразовать из формата времени в целое число вы можете использовать функцию time_to_sec для преобразования времени в количество секунд, а затем делить на 360 для преобразования секунд в часы или использовать секунды вместо часов.

пример

DATE_SUB(enddatetime , INTERVAL (time_to_sec((TimeDIFF(totaltime, Time(enddatetime ))))/3600) HOUR)

Другие вопросы по теме