У меня есть SQL-запрос, который не зависит от таблицы, и я не знаю, как его обрабатывать с помощью Ruby On Rails.
Вот мой SQL-запрос (вам не нужно его понимать):
SELECT type, actor_id, events.created_at, photo_id, photos.user_id FROM (SELECT 'comment' AS type, user_id AS actor_id, created_at, photo_id FROM comments UNION SELECT 'classification' AS type, user_id AS actor_id, created_at, photo_id FROM classifications) AS events INNER JOIN photos ON photo_id = photos.id WHERE user_id = #{@user.id} ORDER BY created_at DESC LIMIT 9
Я попытался создать модель и использовать find_by_sql:
class RecentActivity ActiveRecord::Base
attr_accessor :type, :actor_id, :created_at, :photo_id, :user_id
end
Я получаю:
Mysql::Error: Table 'mysite_development.recent_activities' doesn't exist: SHOW FIELDS FROM `recent_activities`
Как я могу избежать этого сообщения? Есть ли альтернативное решение?