1

嗨,我有一个包含 Channel 模型的 rails 应用程序。其属性如下:

   # Table name: channels
   #
   #  id             :integer          not null, primary key
   #  created_at     :datetime
   #  updated_at     :datetime
   #  channel_name   :string(255)
   #  classification :string(255)      default("0")
   #  ownership      :string(255)      default("0")

我的应用程序中的一个 rake 任务读取了一个 csv 文件并在数据库中填充了信息。这是创建模型的代码的快照

    ...previous code........

    channelName = nil
    classif = nil
    owner = nil
    channelName = row[0].force_encoding('UTF-8')
    classif = row[1].force_encoding('UTF-8')
    owner = row[2].force_encoding('UTF-8') 

if (channelName.nil?)
       puts "Channel name for row #{i} was nil"
       next 
    else                                    
       puts "Creating channel hash with information:"
   puts "channel_name= #{channelName}"
   puts "classification=#{classif}"
   puts "ownership= #{owner}"

   ch = Channel.where(:channel_name =>"#{channelName}").first_or_create do |c|
   c.ownership = "#{owner}"
   c.classification = "#{classif}"

由于该任务能够读取 csv 文件并填充数据库,因此“first_or_create”方法的“create”部分有效。但是,当我更改 csv 文件中的某些内容并重做 rake 任务时,它应该使用更改的内容更新数据库。它不这样做。我想知道这与我的方法的语法有关吗?块部分错了吗?

4

1 回答 1

0

first_or_create的文档没有说如果记录已经存在,它会更新它。它

  1. 如果记录不存在,则创建该记录。
  2. 如果记录已经存在则返回

您必须在获得记录后对其进行更新。

ch = Channel.where(:channel_name =>"#{channelName}").first_or_create do |c|
   c.ownership = "#{owner}"
   c.classification = "#{classif}"
end

ch.update_attribute(:attr, value)
于 2013-10-07T14:41:29.887 回答