加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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 ….)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读