2

我有一条名为 Feeds 的记录,其中包含“last_visited”和“last_modified”字段,两者都是时间戳。

我正在尝试在 last_modified > last_visited 的所有 Feed 视图中呈现列表。

我目前有这个:

控制器

@feeds = @user.feeds

@feeds_hot = @feeds.where(['@feeds.last_modified > ?', @feeds.last_visited])

有一种感觉,我在这里偏离了轨道。我是否也应该使用模型类来做到这一点?

非常感谢任何帮助。

编辑:

这是我的模型

class Feed < ActiveRecord::Base
  attr_accessible :feed_id, :feed_url, :last_modified, :title, :url, :last_visited, :user_id

  belongs_to :user

  scope :hottest, lambda {where('last_modified > ?', :last_visited)}

  def fetch_feed!
   feed = Feedzirra::Feed.fetch_and_parse(feed_url) # probably want some eror handling here
   self.title = feed.title
   self.url = feed.url
   self.last_modified =  feed.last_modified
   self.last_visited  =  feed.last_modified
   self #or nil if you like
  end

  def self.check_for_update(feed)

    fetched_feed = Feedzirra::Feed.fetch_and_parse(feed.feed_url)

    entry = fetched_feed.entries.first
    feed.last_modified = entry.published

  end

 def update_visit_date!
  date = Time.now
  update_attribute(:last_visited, date)
  self
 end

end

编辑

更新代码

控制器

def home
  @user = current_user
  @feeds = @user.feeds
  @feeds_hot = @feeds.hottest
end

模型

attr_accessible :feed_id, :feed_url, :last_modified, :title, :url, :last_visited, :user_id

belongs_to :user

scope :hottest, lambda {where("'last_modified' > ?", 'last_visited')}

看法

%ol.feeds.feeds_hot
  - @feeds_hot.each do |feed|
    %li.feed.hot[feed]
      = render :partial => 'feeds/feed_link', :locals => {:feed => feed}

不幸的是,当我有包含以下数据的提要时,它仍然没有在视图中呈现热门提要:

Last Modified 2013-06-14 23:49:07 UTC
Last Visited 2013-06-14 23:47:55 UTC

上次修改时间比上次访问时间多几个小时

4

1 回答 1

3

如果您希望获取所有 Feed 的列表,这些 Feed 的修改时间比对任何Feed 的最近访问时间要晚,则以下操作将起作用:

last_visit = Feed.order("last_visited").last.last_visited

@feeds = @user.feeds
@hot_feeds = Feed.where("last_modified > ?", last_visited)

编辑:

根据您的评论和对您问题的重新阅读,上面发布的代码将无法完成您想要做的事情。由于您试图获取自上次访问以来已修改的所有邀请的列表,因此您需要创建一个模型scope来使用 ActiveRecord 进行查找。以下代码应该可以工作:

# app/models/feed.rb
class Feed < ActiveRecord::Base
scope :hottest, lambda {where('last_modified > ?', :last_visited)}
end

然后,您可以在控制台、控制器或视图中运行以下命令:

@user.invites.hottest
#=> array of all the user's invites that have been modified more recently than they have been viewed
于 2013-06-14T17:15:36.060 回答