Используя SQLAlchemy, у меня есть отношение "один к большому" с двумя таблицами - пользователями и оценками. Я пытаюсь запросить 10 лучших пользователей, отсортированных по их суммарному баллу за прошлые X дней.
users:
id
user_name
score
scores:
user
score_amount
created
Мой текущий запрос:
top_users = DBSession.query(User).options(eagerload('scores')).filter_by(User.scores.created > somedate).order_by(func.sum(User.scores).desc()).all()
Я знаю, что это явно не правильно, это просто мое лучшее предположение. Однако, посмотрев документацию и поисковый запрос, я не могу найти ответ.
EDIT: Возможно, это помогло бы, если бы я набросал, как выглядит запрос MySQL:
SELECT user.*, SUM(scores.amount) as score_increase
FROM user LEFT JOIN scores ON scores.user_id = user.user_id
WITH scores.created_at > someday
ORDER BY score_increase DESC