rails渴望加载一对多关联

时间:2016-10-12 18:37:57

标签: ruby-on-rails associations one-to-many eager-loading

我有

class Article < ActiveRecord::Base
  has_one :template
end

class Template < ActiveRecord::Base
  has_many :articles
end

其中模型模型有房间属性。现在我想建立一个所有文章的列表,其中文章模板具有一定的房间价值(例如&#34; bath&#34;)。

我认为这是通过急切加载(resp:includes)完成的,但如果我尝试

Article.includes(:template)

我收到错误

SELECT "templates".* FROM "templates" WHERE "templates"."article_id" IN ('51', '52', '53', '54')
ActiveRecord::StatementInvalid: PG::UndefinedColumn: ERROR:  column templates.article_id does not exist
LINE 1: SELECT "templates".* FROM "templates" WHERE "templates"."art...

我做错了什么?

修改

这里是我的schema.rb问题

# encoding: UTF-8
# This file is auto-generated from the current state of the database. Instead
# of editing this file, please use the migrations feature of Active Record to
# incrementally modify your database, and then regenerate this schema definition.
#
# Note that this schema.rb definition is the authoritative source for your
# database schema. If you need to create the application database on another
# system, you should be using db:schema:load, not running all the migrations
# from scratch. The latter is a flawed and unsustainable approach (the more migrations
# you'll amass, the slower it'll run and the greater likelihood for issues).
#
# It's strongly recommended that you check this file into your version control system.

ActiveRecord::Schema.define(version: 20160913122551) do

  # These are extensions that must be enabled in order to support this database
  enable_extension "plpgsql"

  create_table "articles", force: :cascade do |t|
    t.string   "title"
    t.text     "details"
    t.integer  "value_eur"
    t.integer  "deposit_eur"
    t.integer  "location_id"
    t.integer  "user_id"
    t.datetime "created_at",    null: false
    t.datetime "updated_at",    null: false
    t.string   "picture"
    t.float    "rate_eur"
    t.string   "rate_interval"
    t.integer  "template_id"
    t.integer  "quality"
  end

  add_index "articles", ["location_id"], name: "index_articles_on_location_id", using: :btree
  add_index "articles", ["template_id"], name: "index_articles_on_template_id", using: :btree
  add_index "articles", ["user_id"], name: "index_articles_on_user_id", using: :btree

  create_table "locations", force: :cascade do |t|
    t.string   "street_and_no"
    t.string   "postcode"
    t.string   "city"
    t.string   "country"
    t.integer  "user_id"
    t.datetime "created_at",    null: false
    t.datetime "updated_at",    null: false
    t.float    "latitude"
    t.float    "longitude"
  end

  add_index "locations", ["user_id"], name: "index_locations_on_user_id", using: :btree

  create_table "templates", force: :cascade do |t|
    t.string   "title"
    t.text     "details_hint"
    t.float    "rate_eur"
    t.string   "rate_interval"
    t.string   "picture"
    t.datetime "created_at",    null: false
    t.datetime "updated_at",    null: false
    t.string   "room"
  end

  create_table "users", force: :cascade do |t|
    t.string   "email",                  default: "", null: false
    t.string   "encrypted_password",     default: "", null: false
    t.string   "reset_password_token"
    t.datetime "reset_password_sent_at"
    t.datetime "remember_created_at"
    t.integer  "sign_in_count",          default: 0,  null: false
    t.datetime "current_sign_in_at"
    t.datetime "last_sign_in_at"
    t.inet     "current_sign_in_ip"
    t.inet     "last_sign_in_ip"
    t.datetime "created_at",                          null: false
    t.datetime "updated_at",                          null: false
    t.string   "role"
    t.string   "nickname"
    t.string   "firstname"
    t.string   "lastname"
    t.string   "phoneno"
    t.boolean  "showemail"
    t.boolean  "showphone"
  end

  add_index "users", ["email"], name: "index_users_on_email", unique: true, using: :btree
  add_index "users", ["nickname"], name: "index_users_on_nickname", unique: true, using: :btree
  add_index "users", ["reset_password_token"], name: "index_users_on_reset_password_token", unique: true, using: :btree

  add_foreign_key "articles", "locations"
  add_foreign_key "articles", "templates"
  add_foreign_key "articles", "users"
  add_foreign_key "locations", "users"
end

1 个答案:

答案 0 :(得分:0)

根据您发布的schema.rb,您的模板表没有article_id列,因此您需要创建该引用。

更改

has_one :template 

在文章模型中

belongs_to :template