我正在做一个项目,我必须将一些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
结束
那么,有没有办法做到这一点,或者使请求更快?
答案 0 :(得分:3)
在Phone
模型中,您可以添加一个唯一性验证器,如下所示:
validate :imei, uniqueness: true
,这样,当您尝试保存手机时,它不会通过验证并且也不会保存。在这种情况下,它是重复字段的验证器。