Squeak.ru - шаблоны программирования

rails has_many :through с условиями ассоциации с псевдонимом

Этот вид соответствует моему исходному вопросу о has_many :through с условиями, но я обнаружил еще одну проблему.

Учитывая этот класс:

class Contact < AR
  has_many :group_contacts
  has_many :groups, :through => :group_contacts, :conditions => {:published => true}
  has_many :anonymous_groups, :through => :group_contacts, :source => :group, :conditions => {:anonymous => true}
end

Моя проблема возникает, когда я пытаюсь включить anonymous_groups с contacts:

Contact.includes(:anonymous_groups)

ActiveRecord::StatementInvalid: PGError: ERROR: отсутствует запись предложения FROM для таблицы «контакты»

Причина этого в том, что сгенерированный sql неверен. Это что-то вроде:

SELECT "group_contacts"."id" AS t0_r0 ... "groups"."anonymous" AS t1_r5 ... LEFT OUTER JOIN "groups" ON "groups"."id" = "group_contacts"."group_id" WHERE ("group_contacts".contact_id IN (...) AND ("contacts"."anonymous" = 'true'))

Перефразировано конечно, но посмотрите на конечное состояние. Он ставит анонимное условие на contacts, а не groups

Теперь мы можем исправить эту ошибку запроса (которая, я уверен, является ошибкой), но выполнив что-то вроде:

has_many :anonymous_groups, :through => :group_challenges, :source => :group, :conditions => { :groups => {:anonymous => :true} }

Это ставит условие на правильную таблицу в sql, но когда я пытаюсь создать анонимную группу, я получаю это:

contact.anonymous_groups.build

ActiveRecord::UnknownAttributeError: неизвестный атрибут: groups.anonymous

Таким образом, он работает для запросов, но не для построения. Я совершенно уверен, что это ошибка, но мне интересно, сталкивался ли кто-нибудь с этим или есть обходной путь.


Ответы:


1

Я думаю, что что-то вроде :conditions => "groups.anonymous = true" должно работать нормально.

23.12.2011
  • Это странно, я пытался сделать: :conditions => {'groups.anonymous' => true} и это не удалось по той же причине. Но делать это в прямой строке работает. странный. Огромное спасибо 23.12.2011
  • Новые материалы

    Угловая структура архитектуры
    Обратите внимание, что эта статья устарела, я решил создать новую с лучшей структурой и с учетом автономных компонентов: https://medium.com/@marekpanti/angular-standalone-architecture-b645edd0d54a..

    «Данные, которые большинство людей используют для обучения своих моделей искусственного интеллекта, поставляются со встроенным…
    Первоначально опубликовано HalkTalks: https://hacktown.com.br/blog/blog/os-dados-que-a-maioria-das-pessoas-usa-para-treinar-seus-modelos-de-inteligencia-artificial- ja-vem-com-um-vies-embutido/..

    Сильный ИИ против слабого ИИ: различия парадигм искусственного интеллекта
    В последние годы изучению и развитию искусственного интеллекта (ИИ) уделяется большое внимание и прогресс. Сильный ИИ и Слабый ИИ — две основные парадигмы в области искусственного интеллекта...

    Правильный способ добавить Firebase в ваш проект React с помощью React Hooks
    React + Firebase - это мощная комбинация для быстрого и безопасного создания приложений, от проверки концепции до массового производства. Раньше (знаете, несколько месяцев назад) добавление..

    Создайте API с помощью Python FastAPI
    Создание API с помощью Python становится очень простым при использовании пакета FastAPI. После установки и импорта вы можете создать приложение FastAPI и указать несколько конечных точек. Каждой..

    Веселье с прокси-сервером JavaScript
    Прокси-серверы JavaScript — это чистый сахар, если вы хотите создать некоторую общую логику в своих приложениях, чтобы облегчить себе жизнь. Вот один пример: Связь клиент-сервер Мы..

    Получить бесплатный хостинг для разработчиков | Разместите свой сайт за несколько шагов 🔥
    Статические веб-сайты — это веб-страницы с фиксированным содержанием и его постоянным содержанием. Но теперь статические сайты также обрабатывают динамические данные с помощью API и запросов...