- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我想知道是否有任何方法仍然可以将 .order("RANDOM()")
与 will_paginate
一起使用,这样当页面加载并排序时页面,所有帖子将在每个页面上保持不变,直到重新加载主页。
所以要让 localhost:3000/posts?page=1
上的所有帖子保持不变,直到再次访问 localhost:3000(root_path)
。
问题是它会对帖子进行分页,但它目前会为所选的每个页面重新排序,因此您经常会在第 1 页和第 2 页看到帖子。
最佳答案
一种方法是设置 random seed您的数据库正在排序,这样它每次都会返回相同的随机数序列。您可以将此种子存储在用户的 session 中,并仅在需要时重置它。然而,有一个复杂的问题——即使设置随机种子每次都会产生相同的随机数顺序,也不能保证你的数据库每次都会以相同的顺序在你的行上执行它,除非你强制它这样做:
SELECT items.*
FROM (SELECT setseed(0.2)) t
, (SELECT name, rank() OVER (ORDER BY name DESC)
FROM foos ORDER BY name DESC) items
JOIN generate_series(1, (SELECT COUNT(*) FROM foos))
ON items.rank = generate_series
ORDER BY RANDOM()
LIMIT 10;
如您所知,这非常复杂,它会迫使您的数据库将整个表具体化到内存中。它适用于较小的数据集,但如果你有一个大数据集,那就不可能了!
相反,我建议您使用更像 tadman suggested above 的解决方案:生成一页结果,将 id 存储到 session 中,当您需要生成下一页时,只需忽略您已经向用户显示的任何内容。代码如下所示:
class ThingsController < ApplicationController
def index
@page = params[:page].to_i
session[:pages] ||= {}
if ids = session[:pages][@page]
# Grab the items we already showed, and ensure they show up in the same order.
@things = Things.where(id: ids).sort_by { |thing| ids.index(thing.id) }
else
# Generate a new page of things, filtering anything we've already shown.
@things = Things.where(["id NOT IN (?)", shown_thing_ids])
.order("RANDOM()")
.limit(30) # your page size
# Save the IDs into our session so the above case will work.
session[:pages][@page] = @things.map(&:id)
end
end
private
def shown_thing_ids
session[:pages].values.flatten
end
end
此方法使用 session 来存储每个页面上显示的 ID,因此您可以保证在用户返回时显示相同的项目集和顺序。对于新页面,它将排除任何已显示的项目。您可以随时重置缓存:
session.delete(:pages)
希望对您有所帮助!您也可以使用 Redis 或 Memcache 来存储您的页面数据,但如果您希望每个用户的顺序是随机的, session 是一个不错的选择。
关于ruby-on-rails - .order ("RANDOM()") 与 will_paginate gem,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31729711/
当我输入时: gem env 在我的 Windows 系统上,它会生成以下信息: RubyGems Environment: - RUBYGEMS VERSION: 1.3.5 - RUBY
我记得我用过 gem install rails安装 Rails,但今天当我想安装另一个 gem 时,输入 gem install ruby-recaptcha 它失败了,说: You don't h
我有一个要重命名的 gem 。它是published on RubyGems。我最担心的是人们想要更新它。 我看到了两条路,但是我真的很想听听重命名 gem 的人是如何做到的。 1.把旧的变成一个元包
$ gem install passenger Fetching: passenger-4.0.5.gem (100%) ERROR: While executing gem ... (Gem::F
我刚刚用 gem update mime-types 更新了 mime-types gem . gem list显示 mime-types (1.16)在更新之前。更新后gem list显示 mime
如果我构建了一个私有(private) gem(例如,在我的公司内部托管),然后我想在我正在构建的另一个 gem(不是应用程序!)中重用该 gem,我该怎么做? 我应该在哪里放置我的依赖项并告诉我的新
我正在编写一个具有多个 gem 依赖项的 gem,其中一个依赖于破坏新版本向后兼容性的 gem。这让我开始思考——我不希望我正在构建的 gem 变成“那个 gem”,让人们难以更新他们的应用程序。我也
我目前正在构建一个需要 mysql2 gem 的 RoR 项目。我成功安装了 gem 。因为它出现在我的 gem 列表中。 [root@vc2cmmka035538n simple_cms]# gem
我试图在 XP 上构建 capybara-webkit。我关注了this操作说明。它说要进行捆绑安装: $ cd ruby193\capybara-webkit $ bundle install
是否有可能为 Ruby 提供类似“本地”gem 存储库的东西? 我正在开发一个没有管理员权限的自定义 Linux 发行版。 Ruby 安装在机器上 (v.1.8.7),但显然没有安装“gem”或“bu
我是使用 gems 的新手,所以如果我的事实有误,请原谅我。 我想将 Bundler 从 v1.3.5 更新到最新版本 (v1.5.3),所以我尝试这样做: sudo gem install bund
如何使用 gem install 同时安装多个 gem,同时指定我想要的版本? 例子: gem install akami -v 1.2.0 --ignore-dependencies gem in
我正在尝试在 XP 上构建 capybara-webkit。我关注 this instruction .我说: 8) Clone latest version of capybara-webkit f
我正在尝试设置我自己的私有(private) gem 服务器,它应该为我的 gem 提供服务并显示 rdoc。正如我所读,默认的 gem 服务器应该能够做到这一点。由于我不希望除了我自己的所有 gem
假设我的 gem 是 VideoPlayer。文件夹结构是: VideoPlayer/ /bin vidplay.rb /lib VideoPlayer
如何避免 gem 清理特定错误。我在执行 gem 清理时看到以下错误。 Gem::InstallError: gem-wrappers 未安装在 GEM_HOME 中 gem cleanup Clea
我写了一个 gem elastic-beanstalk这将在 rails 项目文件结构中使用,以及在 rails 目录和文件不可用(无需解压缩等)的独立 CI 环境中使用。即正在运行的 Bamboo
运行“sudo gem list --local”和“gem list --local”给我不同的结果。我的 gem 路径设置为我的主文件夹,并且仅包含来自“gem list --local”的 ge
最初,我发布了 Stack Overflow 问题 Ruby on Rails gems... Re-open models (现已删除)。但我认为这个问题太令人困惑了……我会根据我的发现尝试提出不同
我使用 OS X El Capitan 10.11.6 首先,我在安装 pod 时遇到问题,按照本网站中的步骤进行操作后能够找到问题..终端拼出问题是我安装后的 ruby v 2.2.2当我尝试安
我是一名优秀的程序员,十分优秀!