Rails 4 Migration: has_and_belongs_to_many nom de la table
Actuellement, j'essaie de passer un rails 3.2 application rails 4.0. Mais j'ai un problème avec un has_and_belongs_many
modèle.
J'ai créé une application de test et j'ai le même problème. C'est ce que j'ai fait:
Créé deux modèles: foo_clip et foo_url
class FooClip < ActiveRecord::Base
has_and_belongs_to_many :foo_urls
attr_accessible :id, :name
end
class FooUrl < ActiveRecord::Base
has_and_belongs_to_many :foo_clips
attr_accessible :url
end
Après ce que j'ai mis à jour les fichiers de migration:
class CreateFooClips < ActiveRecord::Migration
def change
create_table :foo_clips do |t|
t.string :name
t.timestamps
end
end
end
class CreateFooUrls < ActiveRecord::Migration
def change
create_table :foo_urls do |t|
t.string :url
t.timestamps
end
end
end
Maintenant, j'ai créé le fichier de migration de la has_and_belongs_to_many table
class CreateFooClipsFooUrls < ActiveRecord::Migration
def change
create_table :foo_clips_foo_urls do |t|
t.belongs_to :foo_url
t.belongs_to :foo_clip
end
end
end
Comme dernière étape, j'ai créé un fichier prototype pour les essais de:
foourl1 = FooUrl.create!(:url => 'http://www.google.com')
foourl2 = FooUrl.create!(:url => 'http://www.apple.com')
fooclip1 = FooClip.create!(:name => 'TestClip1')
fooclip1.foo_urls << foourl1
fooclip1.foo_urls << foourl2
fooclip1.save
Maintenant que j'ai fait:
rake db:drop
rake db:create
rake db:migrate
rake db:seed
Et eu cette erreur:
PG::UndefinedTable: ERROR: relation "foo_clips_urls" does not exist
LINE 5: WHERE a.attrelid = '"foo_clips_urls"'::regcla...
^
: SELECT a.attname, format_type(a.atttypid, a.atttypmod),
pg_get_expr(d.adbin, d.adrelid), a.attnotnull, a.atttypid, a.atttypmod
FROM pg_attribute a LEFT JOIN pg_attrdef d
ON a.attrelid = d.adrelid AND a.attnum = d.adnum
WHERE a.attrelid = '"foo_clips_urls"'::regclass
AND a.attnum > 0 AND NOT a.attisdropped
ORDER BY a.attnum
Si je prends un coup d'oeil à la base de données postgres la table est appelé: foo_clips_foo_urls
Des idées pourquoi cela se produit?
source d'informationauteur patrickS
Vous devez vous connecter pour publier un commentaire.
J'ai résolu le problème en ajoutant la join_table nom de chaque modèle comme: