如何解决具有单表继承STI和has_and_belongs_to_manyHABTM关联的Bug
| 使用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\'
这是错误吗?还是我误会了什么?
谢谢
解决方法
这似乎是一个错误,但已在Rails 3.1中解决。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。