vla*_*iim 3 ruby-on-rails ruby-on-rails-3 rails-postgresql rails-activerecord
我在范围内遇到SQL查询问题.我需要返回一个独特的Project.titles及其附带的id的集合,以便在表单中使用.
我可以使用不同的标题
scope :unique_title, select("DISTINCT title")
Run Code Online (Sandbox Code Playgroud)
但是我没有在结果选项中获得价值
= project_form.input :id, collection: current_user.projects.unique_title
结果:
<select>
<option value>Item 1</option>
<option value>Item 2</option>
<option value>Item 3</option>
</select>
Run Code Online (Sandbox Code Playgroud)
所以,在我的范围中添加id:
scope :unique_title, select("DISTINCT title").select("id")
Run Code Online (Sandbox Code Playgroud)
结果给出了值,但现在我的DISTINCT选择已不存在:
<select>
<option value="1">Item 1</option>
<option value="2">Item 2</option>
<option value="3">Item 3</option>
<option value="4">Item 2</option>
<option value="5">Item 2</option>
<option value="6">Item 2</option>
</select>
Run Code Online (Sandbox Code Playgroud)
我认为你将无法选择另一个领域以及Distinct选择保留其独特性.
我想你可能正在寻找GROUP BY在Rails中可以这样使用的东西:
scope :unique_title, select("id, title").group("title")
Run Code Online (Sandbox Code Playgroud)
但是,这将仅选择具有相同标题的组中的第一个.如果您想要所有记录但需要根据标题对它们进行分组,则需要获取所有记录,然后从Ruby中对它们进行分组.
scope :titles, select("id, title")
Run Code Online (Sandbox Code Playgroud)
那你在哪里使用范围,你sh:
Model.titles.all.group_by(&:title).each do |distinct_title, records|
# do something with the distinct title and records having that distinct title
end
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
6915 次 |
| 最近记录: |