ruby-on-rails – 将will_paginate与多个模型一起使用(Rails)
发布时间:2020-12-16 19:11:56 所属栏目:百科 来源:网络整理
导读:很确定我在这里遗漏了一些非常简单的东西: 我正在尝试显示一系列包含两个不同模型实例的页面 – 配置文件和组.我需要按名称属性排序.我可以为每个模型选择所有实例,然后对它们进行排序和分页,但这感觉很邋and且效率低下. 我正在使用mislav-will_paginate,并
很确定我在这里遗漏了一些非常简单的东西:
我正在尝试显示一系列包含两个不同模型实例的页面 – 配置文件和组.我需要按名称属性排序.我可以为每个模型选择所有实例,然后对它们进行排序和分页,但这感觉很邋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 ….) (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |