Benutzer (Modell) Hierarchie, selbstreferenzieller Join
-
06-07-2019 - |
Frage
Ich versuche herauszufinden, wie man eine zweistufige Benutzerbeziehung hat.
Fotografen haben Kunden. Kunden haben einen Fotografen. Beide sind Benutzer.
Ich habe ein Benutzermodell, das so aussieht:
class User < ActiveRecord::Base
#authlogic
has_many :client_associations,
:foreign_key => 'client_id',
:class_name => 'Association',
:dependent => :destroy
has_many :clients, :through => :client_associations
has_one :photographer_association,
:foreign_key => 'photographer_id',
:class_name => 'Association',
:dependent => :destroy
has_one :photographer, :through => :photographer_association
end
Und ein Assoziationsmodell, das aussieht:
create_table "associations", :id => false, :force => true do |t|
t.integer "photographer_id"
t.integer "client_id"
end
class Association < ActiveRecord::Base
belongs_to :client, :class_name => 'User'
belongs_to :photographer, :class_name => 'User'
end
Wenn ich es mit einigen Daten fülle und die Konsole auflöste, laufe ich Benutzer.
Was mache ich falsch?
Lösung
Sie sollten die fremden_keys wechseln:
has_many :client_associations,
:foreign_key => 'photographer_id',
:class_name => 'Association',
:dependent => :destroy
has_many :clients, :through => :client_associations
has_one :photographer_association,
:foreign_key => 'client_id',
:class_name => 'Association',
:dependent => :destroy
has_one :photographer, :through => :photographer_association
Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow