0

我正在做一个项目,我必须将一些导入Phones我的网站。每部手机都有一个 IMEI 和一个 ref_number。

但是,其中一些Phones已经在数据库中,这会使请求更长,并导致 Heroku 上的应用程序错误。

这是我的phones_controller.rb

def import_xlsx
  if params[:xlsx].nil?
    render :import_phones
  else
    filepath = params[:xlsx].path
    xlsx = Roo::Spreadsheet.open(filepath)
    xlsx = Roo::Excelx.new(filepath)
    xlsx.default_sheet = xlsx.sheets.first
    csv = xlsx.to_csv
    csv_options = { col_sep: ',', headers: :first_row, quote_char: '"' }
    csv_new = CSV.new(csv)
    CSV.parse(csv, csv_options) do |row|
      p = Phone.new(imei: row[0], ref_number: row[1])
      p.imei.gsub(/\s+/, "")
      if p.valid?
        p.save!
      else
        flash[:alert] = "#{p.imei}"
      end
    end
  redirect_to phones_import_path, notice: 'Votre fichier à bien été envoyer'
end

结尾

那么,有没有办法做到这一点,或者让请求更快?

4

1 回答 1

3

Phone模型中,您可以添加一个唯一性验证器,如下所示:

validate :imei, uniqueness: true

这样,当您尝试保存手机时,它不会通过验证,也不会被保存。在这种情况下,它是重复字段的验证器。

有关验证器的更多信息

于 2018-10-19T09:01:00.020 回答