Group Rails按属性查询数组

gbe*_*ger 5 sql ruby-on-rails

假设我有这些行:(表示为JSON):

[
  { name: "Bob", age: 10 },
  { name: "Carl", age: 15 },
  { name: "Alice", age: 10 },
  { name: "Derek", age: 20 }
]
Run Code Online (Sandbox Code Playgroud)

我怎样才能在Rails中将这些分组age?例如,我想要这样的东西:

[
  { age: 10, objects: [
    { name: "Bob", age: 10 },
    { name: "Alice", age: 10 }
  ] },
  { age: 15, objects: [
    { name: "Carl", age: 15 }
  ] },
  { age: 20, objects: [
    { name: "Derek", age: 20 }
  ] },
]
Run Code Online (Sandbox Code Playgroud)

gbe*_*ger 15

得到它了!

People.all.group_by(&:age)
Run Code Online (Sandbox Code Playgroud)


agm*_*min 6

如果您实际上正在处理JSON:

people.group_by{|p| p['age'] }
Run Code Online (Sandbox Code Playgroud)

如果要处理ActiveRecord模型:

People.group('id, age')
Run Code Online (Sandbox Code Playgroud)

这里有关于与ActiveRecord分组的其他文档。