|
|
|
m_maxser |
|
||||||
Шустрый Профиль Группа: Участник Сообщений: 77 Регистрация: 5.2.2008 Репутация: нет Всего: нет |
Здравствуйте.
Есть три модели: Zone (зоны), View (просмотры), Banner (банеры). Zone связана с Banner через View связью has_many :through. View, кроме айдишников двух других моделей, содержит много других полей, в том числе: start_date и end_date. Мне нужно, используя как можно меньше запоросов к БД, получить все записи из Zone, включая вложенные друг в друга View и Banner. Я делал так:
Работает почти как надо. Но мне нужно получать только "актуальные" данные, т.е. где, View.end_date больше текущей даты. Пробовал так:
Тоже "почти". Но в этом случае возвращаются не все zones, а только соответствующие условию. Мне нужно, чтобы zones возвращались все, а те для которых условие не выполняется имели пустую (или равную nil) коллекцию views. Пробовал даже так (по совету знакомого):
actual - это scope содержащий условие из предыдущего примера. Возвращает все Zones, но нетерпеливая загрузка перестает быть нетерпеливой :(. Пробовал использовать joins, но успеха недобился. Еще раз повторю вопрос: мне нужно, получить все существующие zones, содержащие только те views, которые соответствуют условию. views в свою очередь должны содержать banner. Если условие не выполняется и у конкретной zone нет ни одной view, то zone.views должна равняться nil Спасибо Это сообщение отредактировал(а) m_maxser - 10.12.2012, 06:13 |
||||||
|
|||||||
Goganchic |
|
|||
Опытный Профиль Группа: Участник Сообщений: 678 Регистрация: 18.6.2004 Репутация: нет Всего: 5 |
как-то так:
условие в filtered_views нужно поменять на свое |
|||
|
||||
Правила форума "Ruby on Rails" | |
|
Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, source777. |
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | Ruby On Rails | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |