Рельсы соединяют на колонке потребителя

Я пытаюсь получить все действия, связанные с пользователями той же школы (строка на объекте пользователя), но ошибка я получаю это:

Не удается присоединить «действие» к ассоциации с именем «пользователи»; возможно, вы
с ошибкой?

activity_controller.рубидий

@school = current_user.school
@bathroom = Activity.includes(:users).where(name: 'Bathroom').where( :user => { :school => @school} )

и схема:

  create_table "activities", force: :cascade do |t|
    t.string   "name"
    t.datetime "created_at", null: false
    t.datetime "updated_at", null: false
    t.integer  "student_id"
    t.string   "status"
    t.integer  "user_id"
    t.index ["student_id"], name: "index_activities_on_student_id"
    t.index ["user_id"], name: "index_activities_on_user_id"
  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.string   "current_sign_in_ip"
    t.string   "last_sign_in_ip"
    t.datetime "created_at",                          null: false
    t.datetime "updated_at",                          null: false
    t.string   "name"
    t.string   "grade"
    t.string   "school"
    t.integer  "maxout"
    t.index ["email"], name: "index_users_on_email", unique: true
    t.index ["reset_password_token"], name: "index_users_on_reset_password_token", unique: true
  end

1 ответ

  1. Не usersно userпотому Activityчто принадлежит User

    @bathroom = Activity.includes(:user).where(name: 'Bathroom').where( :users => { :school => @school} )
    

    Но Userимеет много activitiesтак User.includes(:activities)

    Конечно, вы должны предоставить ассоциации:

    class Activity
      belongs_to :user
    
    class User
      has_many :activities