加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails-3 – 使用rails对Postgres“DISTINCT ON”应用不

发布时间:2020-12-16 19:35:56 所属栏目:百科 来源:网络整理
导读:我有一个rails应用程序: 用户has_many:项目 用户has_many:tasks,:through = :项目 项目has_many:任务 每个任务都有一个里程碑日期. 要显示具有下一个里程碑日期的项目细节表,我使用: @projects = current_user.tasks.joins(:project).select("distinc
我有一个rails应用程序:

用户has_many:项目

用户has_many:tasks,:through => :项目

项目has_many:任务

每个任务都有一个里程碑日期.

要显示具有下一个里程碑日期的项目细节表,我使用:

@projects = current_user.tasks.joins(:project).select("distinct on (projects.id) projects.*,tasks.*").reorder("projects.id,tasks.milestone ASC")

这工作正常

我现在想要对表列进行排序.

根据Postgres DISTINCT ON不可排序,您必须将其包装在另一个select语句中,即SELECT * FROM(SELECT DISTINCT ON ….)ORDER BY column_3

我确实认为正在排序的列可以根据需要进入SQL,即(按项目名称DESC排序):

@projects = current_user.tasks.joins(:project).select("distinct on (projects.name) projects.*,tasks.*").reorder("projects.name DESC,tasks.milestone ASC")

这是有效的,但我也希望能够通过里程碑顺序排列,这样不行.

有人可以告诉我如何转换我的rails查询,以便它可以被任何列排序?

UPDATE

我想我的问题是如何在一个周围的SELECT和ORDER BY中包装一个activerecord查询?

我想我已经设法实现它使用:

inner_query = current_user.tasks.select("distinct on (projects.id) projects.*,tasks.milestone ASC").to_sql
@projects = Task.paginate_by_sql("select * from (#{inner_query}) as user_projects order by user_projects.name",:page => params[:page])

这是最好的方法还是有人想到一个更好的方法? – find / paginate_by_sql似乎是一种解决方法,我宁愿留在activerecord查询领域.

谢谢

解决方法

您正在尝试获取一组项目,但是以current_user.tasks开头.

为什么不从current_user.projects开始,这保证了不同的项目?

@projects = current_user.projects.includes(:tasks).order("projects.name,tasks.milestone")

替代答案

@projects = current_user.projects.joins(:tasks).select('projects.*,min(tasks.milestone) as next_milestone').order('projects.name').group('projects.id')
@projects.each{|p| puts "#{p.name} #{p.next_milestone}"}

这将为每个项目提供一行,并具有计算的最小tasks.milestone值,可通过next_milestone在项目行结果上访问.没有额外的任务记录,只是下一个里程碑日期.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读