ruby-on-rails – 将will_paginate与多个模型一起使用(Rails)

很确定我在这里遗漏了一些非常简单的东西:

我正在尝试显示一系列包含两个不同模型实例的页面配置文件和组.我需要按名称属性排序.我可以为每个模型选择所有实例,然后对它们进行排序和分页,但这感觉很邋and且效率低下.

我正在使用mislav-will_paginate,并想知道是否有更好的方法来实现这一目标?就像是:

[Profile,Group].paginate(...)

会是理想的!

解决方法

好问题,我遇到了几次同样的问题.每次,我通过编写基于sql联合的自己的SQL查询来结束它(它与sqlite和MysqL一起正常工作).然后,您可以通过传递结果使用will paginate( http://www.pathf.com/blogs/2008/06/how-to-use-will_paginate-with-non-activerecord-collectionarray/).不要忘记执行查询来计算所有行.

一些代码行(未经测试)

my_query = "(select posts.title from posts) UNIONS (select profiles.name from profiles)"
total_entries = ActiveRecord::Base.connection.execute("select count(*) as count from (#{my_query})").first['count'].to_i

results = ActiveRecord::Base.connection.select_rows("select * from (#{my_query}) limit #{limit} offset #{offset}")

它是否过度使用?也许,但你得到的查询数量最少,结果也是一致的.

希望能帮助到你.

注意:如果从http参数获得偏移值,则应使用sanitize_sql_for_conditions(即:sql injection ….)

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...