gpt4 book ai didi

ruby-on-rails - Rails 范围 : Select Distinct Title With Values

转载 作者:行者123 更新时间:2023-12-01 10:07:14 25 4
gpt4 key购买 nike

我在处理范围内的 SQL 查询时遇到问题。我需要返回一组唯一的 Project.titles 及其随附的 ID,以便在表单中使用。

我可以使用不同的标题

scope :unique_title, select("DISTINCT title")

但我没有得到结果选项中的值

= project_form.input :id, 集合:current_user.projects.unique_title

结果:

<select>
<option value>Item 1</option>
<option value>Item 2</option>
<option value>Item 3</option>
</select>

因此,将 id 添加到我的范围:

scope :unique_title, select("DISTINCT title").select("id")

结果为我提供了值,但现在我的 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>

最佳答案

我认为您将无法选择另一个字段以及保留其独特性的 Distinct 选择。

我认为您可能正在寻找可以在 Rails 中像这样使用的 GROUP BY:

scope :unique_title, select("id, title").group("title")

但是,这只会从具有相同标题的组中选择第一个。如果您想要所有记录但需要根据它们的标题对它们进行分组,您将需要获取所有记录,然后从 Ruby 中对它们进行分组。

scope :titles, select("id, title")

然后在你使用范围的地方,你应该:

Model.titles.all.group_by(&:title).each do |distinct_title, records|
# do something with the distinct title and records having that distinct title
end

关于ruby-on-rails - Rails 范围 : Select Distinct Title With Values,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9208270/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com