如何查找具有当前用户的Company_id

时间:2015-02-12 23:30:34

标签: ruby-on-rails ruby model associations

我想从当前用户创建一个带有jobdescription的新company_id,但它不起作用,我尝试了不同的方式,但它仍无效。

所以,我不知道如何在我的控制器中构建查询,如果你能告诉我问题在哪里,那将是非常友好的。感谢。

Schema.rb

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

  create_table "companies", force: true do |t|
    t.string   "company_name"
    t.string   "user_id"
    t.datetime "created_at"
    t.datetime "updated_at"
  end



  create_table "jobdescriptions", force: true do |t|
    t.string   "applyjobid"
    t.string   "job_title"
    t.string   "department"
    t.text     "shift"
    t.string   "work_location"
    t.string   "position_supervisor"
    t.string   "supervisor_position_supervisor"
    t.decimal  "rate_pay"
    t.text     "benefits"
    t.text     "other_benefits"
    t.text     "job_summary"
    t.text     "job_duties"
    t.text     "tasks"
    t.text     "results"
    t.text     "responsibilities"
    t.text     "knowledge"
    t.text     "skills"
    t.text     "abilities"
    t.text     "physical_requirement"
    t.text     "work_envir_condition"
    t.text     "protective_clothing_and_devices_required"
    t.text     "tools_or_equipment_required"
    t.text     "qualifications"
    t.text     "education_and_training"
    t.text     "license_certification"
    t.text     "experience"
    t.text     "aptitudes_interests_temperament"
    t.text     "roles_relationships"
    t.text     "supervisory_responsibility"
    t.text     "advancement_promotion_opportunities"
    t.string   "internal_comment"
    t.string   "submited_by"
    t.string   "approved_by"
    t.string   "statut"
    t.date     "from_date"
    t.date     "end_date"
    t.integer  "company_id"
    t.datetime "created_at"
    t.datetime "updated_at"
  end

  add_index "jobdescriptions", ["company_id"], name: "index_jobdescriptions_on_company_id"



  create_table "users", force: true do |t|
    t.string   "username"
    t.string   "country"
    t.string   "role_id"
    t.integer  "company_id"
    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.integer  "current_sign_in_ip"
    t.integer  "last_sign_in_ip"
    t.datetime "created_at"
    t.datetime "updated_at"
  end

  add_index "users", ["company_id"], name: "index_users_on_company_id"
  add_index "users", ["email"], name: "index_users_on_email", unique: true
  add_index "users", ["reset_password_token"], name: "index_users_on_reset_password_token", unique: true

  create_table "users_roles", id: false, force: true do |t|
    t.integer "user_id"
    t.integer "role_id"
  end

  add_index "users_roles", ["user_id", "role_id"], name: "index_users_roles_on_user_id_and_role_id"

end

这是我的 JobdescriptionsController

class JobdescriptionsController < ApplicationController
  layout 'application'



  def new
    @jobdescription = Jobdescription.new
  end

  def create

    @jobdescription = current_user.company_id.jobdescriptions.create(jobdescription_params)
    redirect_to new_jobdescription_path
  end

  private

  def jobdescription_params
    params.require(:jobdescription).permit(:applyjobid, :job_title, :work_location, :rate_pay, :shift, )
  end

end

模型 Jobdescription

class Jobdescription < ActiveRecord::Base
  belongs_to :company


end

模型 Company

class Company < ActiveRecord::Base
  has_many :users
  has_many :jobdescriptions

end

模型 User

class User < ActiveRecord::Base
  rolify
  default_value_for :role_id, "1"
  # Include default devise modules. Others available are:
  # :confirmable, :lockable, :timeoutable and :omniauthable
  devise :database_authenticatable, :registerable,
         :recoverable, :rememberable, :trackable, :validatable
  has_many :timesheets
    has_many :expenses
  belongs_to :company
end

1 个答案:

答案 0 :(得分:0)

我认为问题在于current_user.company_id为该用户的公司提供company_id的整数值,而您实际想要的是获取公司对象实例本身。然后,您可以在该公司实例上调用create

因此@jobdescription方法中create的分配将是:

@jobdescription = current_user.company.jobdescriptions.create(jobdescription_params)