MYSQL: объединить год () и timestampdiff ()

Можно ли совместить функции year() и timestampdiff()? У меня есть столбцы с людьми, датой рождения (dob) и датами событий, и я хотел бы знать возраст этого человека на первое июля (01-07) в год, когда произошло событие.

Это выглядело бы так: timestampdiff(year, dob, "year(event)-01-07")

Очевидно, это не работает. Есть ли способ это вычислить?

Освоение архитектуры микросервисов с 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
В предыдущей статье мы завершили установку базы данных, для тех, кто не знает.
2
0
95
1

Ответы 1

Для этого можно использовать concat.

select
   timestampdiff(year, dob, concat(year(event),'-',month(dob),'-',day(dob)))
from table_name;

или же

select
   timestampdiff(year, dob, concat(year(event),'-',date_format(dob,'%m-%d')))
from table_name;

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