24
25
26
27
28
29
30
31
32
33
|
# File 'lib/rivendell/db/cart.rb', line 24
def self.duplicated(*fields)
sql_fields = fields.join(", ")
query = "select GROUP_CONCAT(NUMBER) as numbers, #{sql_fields} from CART group by #{sql_fields} having count(NUMBER) > 1;"
repository(:default).adapter.select(query).map do |duplicated_group|
field_values = fields.inject({}) { |map, field| map[field] = duplicated_group.send(field); map }
numbers = duplicated_group.numbers.split(",").map(&:to_i)
{ :numbers => numbers, :fields => field_values }
end
end
|