【发布时间】:2013-02-22 23:42:19
【问题描述】:
我有以下应用程序。一部电影有很多评论,一个电影观众有很多评论。 当我尝试将评论与电影相关联时,出现以下错误
Review Load (0.1ms) SELECT "reviews".* FROM "reviews" WHERE "reviews"."movie_id" = 5
SQLite3::SQLException: no such column: reviews.movie_id: SELECT "reviews".* FROM "reviews" WHERE "reviews"."movie_id" = 5
ActiveRecord::StatementInvalid: SQLite3::SQLException: no such column: reviews.movie_id: SELECT "reviews".* FROM "reviews" WHERE "reviews"."movie_id" = 5
使用sql gui编辑器后我发现正确的查询应该是
SELECT "reviews".* FROM "reviews" WHERE "movie_id" = 5
review.rb
class Review < ActiveRecord::Base
belongs_to :movie
belongs_to :moviegoer
attr_protected :moviegoer_id
end
movie.rb 和moviegoer.rb 有
has_many :reviews
在其中。 架构.rb
ActiveRecord::Schema.define(:version => 20130222225620) do
create_table "moviegoers", :force => true do |t|
t.string "name"
t.string "provider"
t.string "uid"
t.datetime "created_at", :null => false
t.datetime "updated_at", :null => false
end
create_table "movies", :force => true do |t|
t.string "title"
t.string "rating"
t.text "description"
t.datetime "release_date"
t.datetime "created_at", :null => false
t.datetime "updated_at", :null => false
end
create_table "reviews", :force => true do |t|
t.integer "potatoes"
t.text "comments"
t.integer "moviegoers_id"
t.integer "movies_id"
end
end
我做错了什么?为什么 rails 会查询“reviews”。“movie_id”而不仅仅是“movie_id”?
【问题讨论】:
-
正如您在评论表中看到的那样,没有“movie_id”列,而是有一个“movies_id”。
标签: sql ruby-on-rails migration