从 CSV 创建两个模型

Creating Two Models From CSV

我正在从 CSV 文件加载信息(姓名、电子邮件地址、状态)。我想从 CSV 文件创建客户和 SurveyRequest。我在网上学习了很多教程,可以创建客户记录,但是创建 SurveyRequest 记录时出错。所有示例都显示了 Customer 中创建记录的方法,但我对如何让 Customer 模型创建 SurveyRequest 感到困惑。我看过了,明白这可能与 Customer 和 SurveyRequest 模型之间的关系有关,但我不确定。

我得到的错误是:

undefined method `survey_request_id' for #<SurveyRequest:0x00007f9197f45378> Did you mean? survey_token_changed?

错误发生在@survey_request.save行

这里是 Customer.rb 模型 class 客户 < ApplicationRecord

  enum status: { active: 0, inactive: 1, removed: 2 }

  belongs_to :product
  #belongs_to :survey_request
  has_many :survey_requests
  has_secure_token :customer_token

  #the below is for importing customers from a CSV file
  def self.import(file, product_id)
    #begin
      CSV.foreach(file.path, headers: true) do |row|
        customer_hash = row.to_hash
        if customer_hash['is_new'].to_i == 1
          @customer = Customer.new(name: customer_hash['name'], email: customer_hash['email'], product_id: product_id) #to whitelist data for entry so it can be saved
          @customer.status = :active
          @customer.save #if saved ok
          #now that customer is saved, need to create a corresponding SurveyRequest
          @product = Product.where("id = ?", @customer.product_id)
          @survey_request = SurveyRequest.new
          @survey_request.product_id = @product.id
          @survey_request.customer_id = @customer.id
          @survey_request.date_to_send = @product.days_after_for_new_customer.days
          @survey_request.save
          #elsif para is_new = 0 then create existing customer
        elsif customer_hash['is_new'].to_i == 0
          #@customer = Customer.new(customer_hash) #to whitelist data for entry so it can be saved
          @customer = Customer.new(name: customer_hash['name'], email: customer_hash['email'], product_id: product_id)
          @customer.status = :active
          @customer.save #if saved ok
          @product = Product.find(@customer.product_id)
          @survey_request = SurveyRequest.new
          @survey_request.product_id = @product.id
          @survey_request.customer_id = @customer.id
          @survey_request.date_to_send = @product.days_after_for_existing_customer.days
          @survey_request.save
        end
    end
  end
end

这里是Survey.rb模型

class SurveyRequest < ApplicationRecord

  enum request_type: { new_customer: 0, existing_customer: 1, new_release: 2, new_customer_reminder: 3, existing_customer_reminder: 4, new_release_reminder: 5 }

  belongs_to :product
  #has_one :customer
  belongs_to :customer
  has_secure_token :survey_token

  attr_accessor :customer_email
  validates :customer_email, :presence => true
  validates :survey_request_id, :presence => true
end

这里是customers_controller.rb文件的导入方法

def import
  @product = Product.find(1)
  #confirm that the user uploading the file to the product is the owner
  if @product.user_id = current_user.id
    Customer.import(params[:file], @product.id)
    flash[:success] = "Customers created."
    redirect_to product_customers_path(:product_id => @product.id)
  else
    flash[:danger] = "It does not appear you are the creator of this product. If you believe you are receiving this message in error, please contact customer support."
    redirect_to users_dashboard_path
  end
end

删除 SurveyRequest 模型中的行: validates :survey_request_id, :presence => true

ID 始终由数据库自动生成,无需验证。该列也将被称为 :id.