Как получить разницу между 2 раза в mysql?

Я пытаюсь найти разницу между 2 раза, когда результаты, которые я хочу, не просто округляются вверх или вниз до ближайшего часа, но есть полчаса

SELECT  (CEILING(ROUND(TIMESTAMPDIFF(MINUTE, TIMESTAMPADD(MINUTE,
    ROUND(TIMESTAMPDIFF(MINUTE,CURDATE(),'2019-04-16 17:30:00')/60)*60,
    CURDATE()),'2019-04-16 21:00:00')/60,1)/ 0.5) * 0.5)

в этом запросе результат составляет 3,0 часа, но я хочу 3,5 часа.

Один из этих ответов решил вашу проблему? Если нет, не могли бы вы предоставить больше информации, чтобы помочь ответить на него? В противном случае, пожалуйста, подумайте о том, чтобы отметить принятый ответ, который лучше всего решил вашу проблему (галочка под стрелками вверх/вниз). См. stackoverflow.com/help/someone-answers

Nick 18.04.2019 14:32
Освоение архитектуры микросервисов с 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
1
46
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Ответ принят как подходящий

Трюк с обработкой времени заключается не в том, чтобы преобразовать его в строку:

SELECT ABS(TIME_TO_SEC(TIMEDIFF('2019-04-16 17:30:00','2019-04-16 21:00:00')))/3600

Если вы хотите округлить до ближайшего получаса, просто используйте TIMESTAMPDIFF с аргументом минут, разделите на 30 (полчаса), а затем ROUND, чтобы получить точное количество получасовых периодов, а затем разделите на 2, чтобы получить число часов с точностью до получаса:

SELECT ROUND(TIMESTAMPDIFF(MINUTE, '2019-04-16 17:30:00','2019-04-16 21:00:00') / 30) / 2

Выход

3.5

Демо на dbfiddle

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