很确定我在这里遗漏了一些非常简单的东西:
我正在尝试显示一系列包含两个不同模型实例的页面 – 配置文件和组.我需要按名称属性排序.我可以为每个模型选择所有实例,然后对它们进行排序和分页,但这感觉很邋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 ….)