У меня есть две таблицы с отношением HABTM в Rails. Примерно так:
class Foo < ActiveRecord::Base
has_and_belongs_to_many :bars
end
class Bar < ActiveRecord::Base
has_and_belongs_to_many :foos
end
Теперь у меня есть новый Foo
объект, и я хочу массово назначить ему тысячи баров, которые я предварительно загрузил:
@foo = Foo.create
@bars = Bar.find_all_by_some_attribute(:a)
Какой самый быстрый способ сделать это? Я пробовал:
@foo.bars = @bars
@foo.bars << @bars
И оба работают очень медленно, с записью, подобной следующей для каждого bar
:
bars_foos Columns (1.1ms) ПОКАЗАТЬ
ПОЛЯ ОТ bars_foos
SQL (0,6 мс)
INSERT INTO bars_foos
(bar_id
,
foo_id
) ЗНАЧЕНИЯ (100, 117200)
Я посмотрел на ar-extensions, но функция import
, похоже, не работает без модели (Model.import), что исключает ее использование для таблицы соединений.
Нужно ли писать SQL или у Rails есть более симпатичный способ?