rails mongodb查找并删除重复项

时间:2015-02-22 06:34:34

标签: ruby-on-rails mongodb ruby-on-rails-4 mongoid4

有没有可以让这个算法更快?

我正在获取此模型(工件)的所有文档,并且我想知道每个文档是否存在重复,如果存在,我将其删除。

   Artifact.all.to_a.each do |n|
      image = n.image_original
      thumb = n.image_thumbnail
      count_value =  Artifact.where(:image_original => image, 
                         :image_thumbnail => thumb).all.to_a.count
      if count_value > 1
        n.destroy!
      end
    end

1 个答案:

答案 0 :(得分:1)

您需要在Artifacts集合上调用uniq方法,如下所示:

@all_artifacts = Artifact.all
@distinct_artifacts = @all_artifacts.uniq {|artifact| artifact.image_original}

您可以像Criteria#distinct一样使用Artifact.distinct(:image_original),但这只会返回仅包含该字段的不同值。