Как получить последнюю транзакцию каждого игрока - SQL Solution

У меня есть база данных, в которой я храню все транзакции, совершенные в игре. (Изображение БД) Теперь я хочу получить значение последней транзакции для каждого игрока.

я уже пробовал SELECT MAX(timestamp), value, account_id FROM transactions GROUP BY account_id;. Здесь я получаю правильное время и account_id, но не правильное значение.

Можно ли решить эту проблему только с помощью SQL?

Версия MySQL???

Salman A 14.05.2022 14:48

Это версия 5.7

Scamander 1920 14.05.2022 16:20
Освоение архитектуры микросервисов с 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
2
26
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Ответ принят как подходящий
select * from table 
where id in (select MAX(id) from table group by account_id)

Это предполагает, что идентификаторы находятся в том же порядке, что и отметка времени. Это верно в большинстве случаев, но нет никаких гарантий.

Salman A 14.05.2022 14:52

@SalmanA, как я могу это исправить?

amirhosein hadi 14.05.2022 15:05

Вы можете использовать корреляцию, например. where timestamp = (select max(timestamp) from transactions as x where account_id = transactions.account_id)

Salman A 14.05.2022 15:07

В MySQL 8 или более поздней версии вы можете использовать для этого оконные функции:

with cte as (
    select *, row_number() over (partition by account_id order by timestamp desc) as rn
    from transactions
)
select *
from cte
where rn = 1

Спасибо!! К сожалению, моя версия MYSQL 5.7, и я не могу ее обновить.

Scamander 1920 14.05.2022 16:27

Используйте комментарий под другим ответом.

Salman A 14.05.2022 16:49

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