如何显示 company_name 而不是 company_id

How to display company_name instead of company_id

我有一个模型可以存储我的 jobdescription,还有一个视图 Jobdetails 可以向外界显示作业,但是当我想显示 company_name 来自我的 Company 模型,而不是 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

Jobdetails Controller

 class JobdetailsController < ApplicationController
   layout 'apply'

       def show
         @jobdetail = Jobdescription.find_by_applyjobid(params[:applyjobid])
         @nm = @jobdetail.company_name
       end

   end

型号Jobdescription

  class Jobdescription < ActiveRecord::Base
    belongs_to :company
  end

型号Company

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

查看Jobdetails/show

 <strong>Company name:</strong>
 <%= @nm %>

Jobdetail 模型没有 company_name 方法,但 Company 有。只需更改 @nm assignment 即可通过公司协会获取公司名称:

@nm = @jobdetail.company.company_name

您可以在模型中添加 company_name 作为方法,就像您多次使用它一样。

def company_name
 company.company_name
end

那你就可以直接使用了

@jobdetail.company_name