2017-04-26 3 views
-1

hinzuzufügen. Ich versuche, einem Mitarbeiter über ein employee_skill-Tabellenformular auf der show-Seite für Mitarbeiter eine Fähigkeit hinzuzufügen, bekomme aber jedes Mal, wenn ich es versuche, den folgenden Fehler um es zu schaffen.Konnte '' mit ID = nicht finden, wenn ich versuche, zur Tabelle

Fehler:

ActiveRecord::RecordNotFound in EmployeeSkillsController#create 

Couldn't find Employee with 'id'= 

Mitarbeiter anzeigen

die Fähigkeiten der Mitarbeiter-Controller

# POST /employee_skills 
    # POST /employee_skills.json 
    def create 

    @employee_skill = EmployeeSkill.new 
    @employee = Employee.find(params[:employee_id]) 
    @employee_skill.employee_id= @employee.id 


    respond_to do |format| 
     if @employee_skill.save 
     #session[:employee_id] = nil 
     format.html { redirect_to @employee, notice: 'Employee skill was successfully created.' } 
     format.json { render :show, status: :created, location: @employee_skill } 
     else 
     format.html { render :new } 
     format.json { render json: @employee_skill.errors, status: :unprocessable_entity } 
     end 
    end 
    end 

UPDATE

Protokolldatei

Started POST "/employee_skills" for ::1 at 2017-04-26 12:35:38 +0100 
Processing by EmployeeSkillsController#create as HTML 
    Parameters: {"utf8"=>"✓", "authenticity_token"=>"bJ/wgo1Iz7KqLDtijEZ/emuWTuS4UblMlVnz7SyBZUSR7MJlxAmtXk5LS661t6598WfnCycDf6LtUHwhTOf9hQ==", "employee_skill"=>{"skill_id"=>"1", "skillLevel"=>"3"}} 
    [1m[35mEmployee Load (0.5ms)[0m SELECT "employees".* FROM "employees" WHERE "employees"."id" = ? LIMIT 1 [["id", 1]] 
    [1m[36mEmployee Load (1.0ms)[0m [1mSELECT "employees".* FROM "employees" WHERE "employees"."id" = ? LIMIT 1[0m [["id", nil]] 
Completed 404 Not Found in 22ms (ActiveRecord: 1.5ms) 

ActiveRecord::RecordNotFound (Couldn't find Employee with 'id'=): 
    app/controllers/employee_skills_controller.rb:31:in `create' 


    Rendered C:/RailsInstaller/Ruby2.1.0/lib/ruby/gems/2.1.0/gems/actionpack-4.2.6/lib/action_dispatch/middleware/templates/rescues/_source.erb (1.5ms) 
    Rendered C:/RailsInstaller/Ruby2.1.0/lib/ruby/gems/2.1.0/gems/actionpack-4.2.6/lib/action_dispatch/middleware/templates/rescues/_trace.html.erb (12.0ms) 
    Rendered C:/RailsInstaller/Ruby2.1.0/lib/ruby/gems/2.1.0/gems/actionpack-4.2.6/lib/action_dispatch/middleware/templates/rescues/_request_and_response.html.erb (5.0ms) 
    Rendered C:/RailsInstaller/Ruby2.1.0/lib/ruby/gems/2.1.0/gems/actionpack-4.2.6/lib/action_dispatch/middleware/templates/rescues/diagnostics.html.erb within rescues/layout (292.9ms) 
    Rendered C:/RailsInstaller/Ruby2.1.0/lib/ruby/gems/2.1.0/gems/web-console-2.3.0/lib/web_console/templates/_markup.html.erb (2.0ms) 
    Rendered C:/RailsInstaller/Ruby2.1.0/lib/ruby/gems/2.1.0/gems/web-console-2.3.0/lib/web_console/templates/_inner_console_markup.html.erb within layouts/inlined_string (1.5ms) 
    Rendered C:/RailsInstaller/Ruby2.1.0/lib/ruby/gems/2.1.0/gems/web-console-2.3.0/lib/web_console/templates/_prompt_box_markup.html.erb within layouts/inlined_string (2.0ms) 
    Rendered C:/RailsInstaller/Ruby2.1.0/lib/ruby/gems/2.1.0/gems/web-console-2.3.0/lib/web_console/templates/style.css.erb within layouts/inlined_string (1.5ms) 
    Rendered C:/RailsInstaller/Ruby2.1.0/lib/ruby/gems/2.1.0/gems/web-console-2.3.0/lib/web_console/templates/console.js.erb within layouts/javascript (485.7ms) 
    Rendered C:/RailsInstaller/Ruby2.1.0/lib/ruby/gems/2.1.0/gems/web-console-2.3.0/lib/web_console/templates/main.js.erb within layouts/javascript (1.0ms) 
    Rendered C:/RailsInstaller/Ruby2.1.0/lib/ruby/gems/2.1.0/gems/web-console-2.3.0/lib/web_console/templates/error_page.js.erb within layouts/javascript (3.0ms) 
    Rendered C:/RailsInstaller/Ruby2.1.0/lib/ruby/gems/2.1.0/gems/web-console-2.3.0/lib/web_console/templates/index.html.erb (885.4ms) 
+0

Veröffentlichen Sie die Parameter, die von Ihrem Protokoll an Ihre Erstellungsaktion gesendet werden. – bkunzi01

+0

Log auf die Frage hinzugefügt – David16

+0

'params [: employee_id]' ist nirgends in den Parametern, deshalb passiert dies. – Iceman

Antwort

1

eine Instanz von EmployeeSkill in show Aktion initialisieren

@employee = Employee.find(params[:id]) 
@employee_skill = @employee.employee_skills.new 
# The above statement will set :employee_id with employee's id 

Und es dann in Form verwendet

<%= form_for([@employee, @employee_skill]) do |f| %> 

Sie können auch explizit die :url passieren, wenn sie nicht richtig erzeugt

<%= form_for([@employee, @employee_skill], url: employee_employee_skills_path(@employee)) do |f| %> 
+0

sind gerade um diese jetzt zu versuchen, eine immer „nicht definierte Methode' employee_employee_skills_path‘für # <# : 0x884c520>“ Fehler – David16

+0

Das war mein rate für die Route. Sie sollten die Route überprüfen, ob es richtig ist oder nicht –

+0

versuchen Sie 'rake routes' und entsprechende URL –

Verwandte Themen