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

前端之家收集整理的这篇文章主要介绍了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 ….)

猜你在找的Ruby相关文章