Ошибка с наследованием единой таблицы (STI) и ассоциациями has_and_belongs_to_many (HABTM) - PullRequest
3 голосов
/ 29 мая 2011

Используя Rails 3.0.7, и имеют следующие 4 модели:

class User < ActiveRecord::Base
end

class Administrator < User
  has_and_belongs_to_many :clients
end

class Client < ActiveRecord::Base
  has_and_belongs_to_many :administrators
  has_and_belongs_to_many :meetings
end

class Meeting < ActiveRecord::Base
  has_and_belongs_to_many :clients

  def self.foo
    self.joins(:clients => :administrators)
  end
end

Вызов:

Meeting.foo.to_sql

производит:

SELECT meetings.*
FROM meetings
INNER JOIN clients_meetings ON clients_meetings.event_id = meetings.id
INNER JOIN clients ON clients.id = clients_meetings.child_id
INNER JOIN clients_administrators ON clients_administrators.child_id = clients.id
INNER JOIN users ON users.type = 'Administrator'

, но он появляетсякак будто окончательные отношения соединения между "clients_administrators" и "users" были пропущены.Я думаю, что последняя строка SQL должна читать:

INNER JOIN users ON users.id = clients_administrators.user_id
WHERE users.type = 'Administrator'

Это ошибка?или я что-то не так понял?

Спасибо

1 Ответ

1 голос
/ 31 мая 2011

Это похоже на ошибку , но она была исправлена ​​в Rails 3.1.

...