我正在尝试使用 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!