has_many: a través de, la asociación de uno mismo de referencia
-
20-09-2019 - |
Pregunta
tengo problemas con la asociación uno mismo de referencia, los modelos debería dar ma una serie de modelos para las left_chunks y right_chunks métodos, pero consigo cada vez una matriz vacía
La fuente
class Chunk < ActiveRecord::Base
has_many :left_bindings, :foreign_key => "left_chunk_id",
:class_name => "ChunkChunk",
:dependent => :destroy
has_many :right_chunks, :through => :left_bindings
has_many :right_bindings, :foreign_key => "right_chunk_id",
:class_name => "ChunkChunk",
:dependent => :destroy
has_many :left_chunks, :through => :right_bindings
end
class ChunkChunk < ActiveRecord::Base
belongs_to :left_chunk, :class_name => "Chunk", :foreign_key => "left_chunk_id"
belongs_to :right_chunk, :class_name => "Chunk", :foreign_key => "right_chunk_id"
end
Salida de ./script/console
>> #first case
?>
?> left = Chunk.new({:content => "chunk_one"}); left.save
=> true
>> right = Chunk.new({:content => "chunk_two"}); right.save
=> true
>> left.right_chunks << right
=> []
>> left.right_chunks
=> []
>> left.left_chunks
=> []
>>
?> #second case
?>
?> left = Chunk.new({:content => "chunk_three"}); left.save
=> true
>> right = Chunk.new({:content => "chunk_four"}); right.save
=> true
>> right.left_chunks << left
=> []
>> right.left_chunks
=> []
>> right.right_chunks
=> []
¿Por qué los trozos no unidos?
base de datos después de la ejecución de código
mysql> select * from chunks;
+----+-------------+---------------------+---------------------+
| id | content | created_at | updated_at |
+----+-------------+---------------------+---------------------+
| 1 | chunk_one | 2010-02-14 12:11:22 | 2010-02-14 12:11:22 |
| 2 | chunk_two | 2010-02-14 12:11:22 | 2010-02-14 12:11:22 |
| 3 | chunk_three | 2010-02-14 12:11:22 | 2010-02-14 12:11:22 |
| 4 | chunk_four | 2010-02-14 12:11:22 | 2010-02-14 12:11:22 |
+----+-------------+---------------------+---------------------+
mysql> select * from chunk_chunks;
+----+---------------+----------------+---------------------+---------------------+
| id | left_chunk_id | right_chunk_id | created_at | updated_at |
+----+---------------+----------------+---------------------+---------------------+
| 1 | NULL | 2 | 2010-02-14 12:11:22 | 2010-02-14 12:11:22 |
| 2 | 3 | NULL | 2010-02-14 12:11:22 | 2010-02-14 12:11:22 |
+----+---------------+----------------+---------------------+---------------------+
¿Alguna idea?
Solución
Usted no dice qué versión de MySQL, Ruby o rieles que se encuentra. Acabo de intentar esto con una pequeña prueba y funcionó correctamente. Estoy usando PostgreSQL 8.4.1 en OS X 10.6. Acabo de crear una aplicación vacía en Rails 2.3.5 / Ruby 1.8.7 (2009-06-12 Patchlevel 174) con "carriles testapp", a continuación, añade dos modelos en chunk.rb:
class Chunk < ActiveRecord::Base
has_many :left_bindings, :foreign_key => "left_chunk_id",
:class_name => "ChunkChunk",
:dependent => :destroy
has_many :right_chunks, :through => :left_bindings
has_many :right_bindings, :foreign_key => "right_chunk_id",
:class_name => "ChunkChunk",
:dependent => :destroy
has_many :left_chunks, :through => :right_bindings
end
... y chunk_chunks.rb:
class ChunkChunk < ActiveRecord::Base
belongs_to :left_chunk, :class_name => "Chunk", :foreign_key => "left_chunk_id"
belongs_to :right_chunk, :class_name => "Chunk", :foreign_key => "right_chunk_id"
end
... además de dos migraciones de agregar las tablas, sin marcas de tiempo por razones de brevedad:
class AddChunks < ActiveRecord::Migration
def self.up
create_table 'chunks' do | t |
t.string :content
end
end
def self.down
drop_table 'chunk'
end
end
... y:
class AddChunkChunks < ActiveRecord::Migration
def self.up
create_table 'chunk_chunks' do | t |
t.belongs_to :left_chunk
t.belongs_to :right_chunk
end
end
def self.down
end
end
Entonces corrió "rake db: crear", "rake db: migrate" y sus comandos de la consola trabajado para mí de la siguiente manera:
PondPro:testapp adh1003$ script/console
Loading development environment (Rails 2.3.5)
>> left = Chunk.new({:content => "chunk_one"}); left.save
=> true
>> right = Chunk.new({:content => "chunk_two"}); right.save
=> true
>> left.right_chunks << right
=> [#<Chunk id: 2, content: "chunk_two">]
>> left.right_chunks
=> [#<Chunk id: 2, content: "chunk_two">]
>> left.left_chunks
=> []
>> left = Chunk.new({:content => "chunk_three"}); left.save
=> true
>> right = Chunk.new({:content => "chunk_four"}); right.save
=> true
>> right.left_chunks << left
=> [#<Chunk id: 3, content: "chunk_three">]
>> right.left_chunks
=> [#<Chunk id: 3, content: "chunk_three">]
>> right.right_chunks
=> []
El contenido de base de datos después de la anteriormente fueron:
chunk-devel=# SELECT * FROM chunks;
id | content
----+-------------
1 | chunk_one
2 | chunk_two
3 | chunk_three
4 | chunk_four
(4 rows)
chunk-devel=# SELECT * FROM chunk_chunks;
id | left_chunk_id | right_chunk_id
----+---------------+----------------
1 | 1 | 2
2 | 3 | 4
(2 rows)
Teniendo en cuenta esto:
... y esto:
... No puedo ver nada realmente mal con su código original. Tal vez las migraciones no son los que esperaba, tal vez hay otras partes de su código que no puesto que están interfiriendo (por ejemplo, filtros, otras gemas) o tal vez el adaptador de la base de datos de ActiveRecord para MySQL no está haciendo las cosas bien en este caso y / o MySQL no está funcionando correctamente. Es un poco largo aliento para instalar PostgreSQL y el uso que en lugar de MySQL para más pruebas, pero creo que valdría la pena.
Sólo en caso de que resulte útil en absoluto He subido los datos de la aplicación de prueba aquí:
Si se entera de lo que salió mal y administrar para corregirlo, por favor enviar un seguimiento aquí. Esto será útil si alguien se encuentra con problemas similares en el futuro y lee este hilo durante la búsqueda de una solución.
Otros consejos
¿Es un problema .Reload? Después de hacer esto en la consola:
right.left_chunks << left
DO
right.reload
A continuación, intente
right.left_chunks
.