将两个查询合并为一个并一起分页

发布于 2024-11-17 17:42:34 字数 560 浏览 6 评论 0原文

我有两个范围查询需要一起分页。单独而言,它们看起来像这样:

a = @person.company.tasks.open.paginate :page => params[:page], :order => (sort_column + " " + sort_direction)
b = @person.tasks.private.paginate :page => params[:page], :order => (sort_column + " " + sort_direction)

我想做类似以下的事情:

@tasks = (a + b).paginate :page => params[:page], :order => (sort_column + " " + sort_direction)

我执行 @tasks = (a + b) 并对结果进行分页时,我成功地进行了合并。

没有什么作用

将变量加在一起后,排序就不再起作用了。

I have two scoped queries that I need to paginate together. Individually, they look like this:

a = @person.company.tasks.open.paginate :page => params[:page], :order => (sort_column + " " + sort_direction)
b = @person.tasks.private.paginate :page => params[:page], :order => (sort_column + " " + sort_direction)

I would like to do something like the following:

@tasks = (a + b).paginate :page => params[:page], :order => (sort_column + " " + sort_direction)

What works

I do successfully get a merge when I do @tasks = (a + b) and the results paginate.

What doesn't

With the variables added together, the sorting doesn't work any more.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

天气好吗我好吗 2024-11-24 17:42:34

您可以进行一个查询,根据 2 个查询返回的 id 获取任务:

company_task_ids = @person.company.tasks.open.pluck(:id)
private_task_ids = @person.tasks.private.pluck(:id)
@tasks = Task.where(:id => (company_task_ids + private_task_ids)).paginate :page => params[:page], :order => (sort_column + " " + sort_direction)

这可以稍微优化一下,但这应该可以让您上路

You can make one query, getting the tasks based on the id's returned by the 2 queries:

company_task_ids = @person.company.tasks.open.pluck(:id)
private_task_ids = @person.tasks.private.pluck(:id)
@tasks = Task.where(:id => (company_task_ids + private_task_ids)).paginate :page => params[:page], :order => (sort_column + " " + sort_direction)

This can be optimised a bit, but this should get you on your way

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文