比较两条记录并获取 rails 活动记录中已更改列的名称



我需要比较两个活动记录并获取更改列的名称

#<Evaluation id: 1, name: "Foo", status: "yes", comments: "can be better", created_at: "2017-05-09 12:00:00", updated_at: "2017-05-09 12:00:00">    
#<Evaluation id: 2, name: "Foo", status: "yes", comments: "keep up the good work", created_at: "2017-05-09 12:05:00", updated_at: "2017-05-09 12:05:00">

我需要比较这两个记录并获取更改列的名称。在这种情况下:comments, :created_at, :updated_at

我尝试过使用eql?record1.attributes.except('id') == record2.attributes.except('id')

这些只返回真或假,我也需要获取列名。这可以通过比较每列来完成,但我正在寻找任何其他选项。

您可以使用一个小方法来为您执行此操作:

def diff_active_record(record_a, record_b)
   (record_a.attributes.to_a - record_b.attributes.to_a).map(&:first)
end

此方法将采用两个active_record对象(在本例中为:record_arecord_b(来比较并生成已更改的属性名称数组。

你可以这样使用它:

diff_active_record(Evaluation.find(1), Evaluation.find(2)) 

以上将导致[:id, :comments, :created_at, :updated_at]

最新更新