Sobes.tech
Back to questions
Senior
4

Спроектируйте отношения (таблицы сообщений и агентов) и напишите SQL-запрос, возвращающий топ-5 агентов, ответы которых нравятся пользователям. Поле реакции принимает значения -1, 0, 1.

Companies where asked
Сбербанк

Answer from AI

sobes.tech AI

Для хранения сообщений и агентов можно спроектировать две таблицы:

agents

  • agent_id (PK)
  • name

messages

  • message_id (PK)
  • agent_id (FK)
  • content
  • reaction (INT, принимает значения -1, 0, 1)

SQL-запрос для получения топ-5 агентов с наибольшим средним значением реакции (то есть чьи ответы больше нравятся пользователям):

SELECT a.agent_id, a.name, AVG(m.reaction) AS avg_reaction
FROM agents a
JOIN messages m ON a.agent_id = m.agent_id
GROUP BY a.agent_id, a.name
ORDER BY avg_reaction DESC
LIMIT 5;

Этот запрос вычисляет среднее значение реакции по сообщениям каждого агента и сортирует их по убыванию, возвращая топ-5.