2

我正在尝试使用 activerecord-import gem 导入与用户相关的大量记录。这里的角色与用户有拥有和属于许多关系。导入用户数据时导入成功。但是没有导入role_ids..

我已经尝试通过获取有效的数据邮件 ID 并从该有效的邮件 ID 中查找用户并更新角色 ID。它取得了成功。我需要知道使用活动记录导入的其他一些可用方法。

用户参数:-

  def user_params
    params.require(:user).permit(:email, :first_name, :last_name, role_ids: [])
  end

导入方式:-

  def import(import)
    valid_rows = []
    all_roles = {}
    file = Paperclip.io_adapters.for(self.file).read
    Role.all.select(:id, :name).map { |role| all_roles[role.name.gsub(/[^A-Za-z]/, '').downcase] = role.id }

    CSV.parse(file, headers: true, skip_blanks: true, header_converters: ->(header) { header.strip }, converters: ->(data) { data ? data.strip : nil }).each do |row|
      user_role_name = (row['roles'].gsub(/[^A-Za-z]/, '').downcase || [])
      role_ids = [all_roles[user_role_name]] || []
      attributes = { first_name: row['first_name'], last_name: row['last_name'], email: row['email'], role_ids: role_ids}
      row = User.new(attributes)
      if User.new(attributes).valid?
        valid_rows << row
    end

    User.import valid_rows

  end

有人可以解释如何在导入时使用用户数据导入角色 ID!

4

0 回答 0