0

首先,我真的很抱歉提出这样一个基本问题,但我对 Rails、Ruby 和开发一般来说还是很陌生,而且我缺乏对术语的理解意味着我很难找到这个问题的答案。

我正在使用以下方法导入车辆数据的 csv:

def self.import(file, category_id)
CSV.foreach(file.path, headers: true) do |row|
  Model.where(
  :category_id => category_id, 
  :name => row[1],
  :cap_id => row[10] 
  ).first_or_create do |record|
    record.layout = row[3],

...后来的几条记录...

    record.manufacturer_id = Manufacturer.where(:name => row[0], :category_id => category_id).id
  end
end
end

但我无法使用循环的最后一行设置制造商 ID。我想你可以看到我在这里尝试做什么,但我不知道应该怎么写。

基本上我有一个属于不同类别的制造商列表(例如,有一个福特制造商的 category_id=1(用于汽车)和另一个福特制造商的 category_id=54 用于卡车。

我可以通过从csv中获取当前的category_id和制造商名称来设置每条记录的manufacturer_id,交叉引用它们并拉回结果的id吗?

尝试上述代码时,出现以下错误:

NoMethodError in ModelsController#import
undefined method `id' for #<ActiveRecord::Relation::ActiveRecord_Relation_Manufacturer:0x007fcd96f744a8>
Extracted source (around line #33):

32      record.description = row[2],
33      record.manufacturer_id = Manufacturer.where(:name => row[0], :category_id => category_id).id
34    end
35    end
36  end
4

1 回答 1

1

以下代码行返回一个ActiveRecord::Relation对象

Manufacturer.where(:name => row[0], :category_id => category_id)

因此,当您调用id它时,它会引发错误。你应该first先打电话,然后再打电话id

Manufacturer.where(:name => row[0], :category_id => category_id).first.id

请注意,这样做假定您总是会得到符合条件的制造商。为了更安全,您可以使用try

Manufacturer.where(:name => row[0], :category_id => category_id).first.try(:id)
于 2013-07-19T09:45:26.373 回答