Můžete přimět databázi, aby provedla třídění a vyhnout se vícenásobnému index
musíte si pamatovat, že příkaz SQL ORDER BY objednává pomocí výrazu , nikoli sloupec :
whens = item_ids.collect.with_index { |id, i| "when #{id} then #{i}" }.join(' ')
items = Item.where(:id => item_ids).order("case id #{whens} end")