在Rails 4中通过关联与join table和has_many一起出现问题

时间:2015-11-17 08:07:39

标签: ruby-on-rails ruby ruby-on-rails-4 activerecord strong-parameters

伙计这是我的数据库结构。 AccountGrade.rb为账户&等级模型

class AccountGrade < ActiveRecord::Base
  belongs_to :account
  belongs_to :grade
  attr_accessor :grade
  attr_accessor :section
end

我的帐号.rb模型

class Account < ActiveRecord::Base
  has_many :grades, :through => :account_grades
  has_many :account_grades
  belongs_to :user
  validates :school_name,:line_1,:city,:state,:country,:pincode,:phone_number, :presence => true
  validates :pincode,:phone_number,numericality: { only_integer: true }
end

我的成绩.rb模型

class Grade < ActiveRecord::Base
  has_many :accounts, :through => :account_grades
  has_many :account_grades
  attr_accessor :account_grades
end

我的grades_controller.rb

class GradesController < ApplicationController
  def index
    @grades = Grade.all
    render json: {
      Grades:@grades
    }.to_json
  end

  def add_class_sections
    # unless params[:section]
      @account_grades = AccountGrade.new class_sections_params
      puts "Grades are #{@account_grades}"

      @grades.each do |grade|
        @account_grades = grade
        puts grade
        puts @account_grades
      end
    # end #unless ends here
  end #function add_class_sections ends here


  private

    def class_sections_params
      params.permit!
      # params.require(:gardes).permit(:section)#, :email, :password, :salt, :encrypted_password)
    end

end #class ends here

我在终端跟踪中收到以下错误。

Started POST "/add_classes?grade_id[0]=1&section[0]=2&grade_id[1]=2&section[1]=1&grade_id[2]=3&section[2]=1" for 127.0.0.1 at 2015-11-17 12:43:47 +0530
  ActiveRecord::SchemaMigration Load (0.1ms)  SELECT `schema_migrations`.* FROM `schema_migrations`
Processing by GradesController#add_class_sections as */*
  Parameters: {"grade_id"=>{"0"=>"1", "1"=>"2", "2"=>"3"}, "section"=>{"0"=>"2", "1"=>"1", "2"=>"1"}}
Completed 500 Internal Server Error in 10ms (ActiveRecord: 0.8ms)

ActiveRecord::UnknownAttributeError (unknown attribute 'controller' for AccountGrade.):
  app/controllers/grades_controller.rb:11:in `add_class_sections'


  Rendered /home/anjan/.rvm/gems/ruby-2.2.1/gems/actionpack-4.2.4/lib/action_dispatch/middleware/templates/rescues/_source.erb (11.0ms)
  Rendered /home/anjan/.rvm/gems/ruby-2.2.1/gems/actionpack-4.2.4/lib/action_dispatch/middleware/templates/rescues/_trace.html.erb (1.7ms)
  Rendered /home/anjan/.rvm/gems/ruby-2.2.1/gems/actionpack-4.2.4/lib/action_dispatch/middleware/templates/rescues/_request_and_response.html.erb (0.9ms)
  Rendered /home/anjan/.rvm/gems/ruby-2.2.1/gems/actionpack-4.2.4/lib/action_dispatch/middleware/templates/rescues/diagnostics.html.erb within rescues/layout (24.8ms)

2 个答案:

答案 0 :(得分:1)

哇,您的代码存在很多问题。

无论你的推理如何,这都是你应该如何运作......

#app/controllers/grades_controller.rb
class GradesController < ApplicationController
    def index
      @grades = Grade.all
      respond_to do |format|
         format.json { render json: @grades.to_json }
         format.html
      end
    end

    def create
      @account_grades = AccountGrade.new class_sections_params
      redirect_to @account.grades if @account_grades.save
    end

  private

    def sections_params
      params.require(:grades).permit(:section)
    end
end

如果您使用此代码,您将处于更有利的位置,以了解它为什么要查找controller属性(这是一个奇怪的错误)。

您还应该了解Rails中的几个约定:

  1. 不要在控制器中使用puts - 您有Rails.logger.info()输出到您的控制台。
  2. 保持你的行动安静 - 虽然这可以 - 而且经常 - 被打破,但Rails控制器的宁静性质应该是最重要的惯例。不要打电话给add_class_section,除非你真的需要 - 相反,你应该考虑使用new&amp;根据需要create方法。
  3. -

    此外,删除所有attr_accessor引用,尤其是与任何关联名称冲突的引用。

    attr_accessor基本上为您的模型声明了新的getter / setter方法。如果这些方法覆盖任何关系,它们实际上会阻止它们工作。

    您不需要attr_accessor,除非您想要创建半持久属性(IE不会保存到数据库中)。 Rails中attr_accessor的最常见用途是创建virtual attributes

    enter image description here

答案 1 :(得分:0)

这就是我想要实现的目标。我们欢迎任何关于重新分解或改进以下代码的建议。

class GradesController < ApplicationController
  before_filter :authenticate, only: [:create]

    def index
      @grades = Grade.all
      render json: @grades.to_json
    end

    def create
      @section_name_counter = 0
      @section_names=["A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S",
                     "T","U","V","W","X","Y","Z"]
      @account_grades = AccountGrade.new #sections_params
      @account_grades.grade_id = params[:grade_id]
      @account_grades.account_id = params[:account_id]
      @account_grades.save!

      while @section_name_counter < params[:section].to_i do
        @section = Section.new
        @section.account_grade_id = @account_grades.id
        @section.name = @section_names[@section_name_counter]
        @section.save!
        @section_name_counter += 1
      end
      render json: @account_grades if @section.save
    end

  private

    def sections_params
      params.require(:grade_id).permit(:section,:account_id)
    end
end