首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Rails:带有自定义路由的数据库记录.?

Rails:带有自定义路由的数据库记录.?
EN

Stack Overflow用户
提问于 2009-04-24 17:59:52
回答 1查看 839关注 0票数 0

我有一个模型,目标,有很多记录是有时间戳的。在相应的控制器上,我通过以下操作列出这些记录的月份:

models/target.rb

代码语言:javascript
运行
复制
def month
   self.recorded_on.strftime('%B')
end

controllers/targets_controller.rb

代码语言:javascript
运行
复制
@records = Target.find :all

views/targets/index.html.haml

代码语言:javascript
运行
复制
%ul
  - @records.group_by(&:month).sort.each do |month, data|
    %li= link_to month, ''

这对于列出我所拥有的记录的可用月份都很有用。接下来,我希望能够单击月份,并在用年份和月份生成的以下路径中获取该月份所有记录的报告:/targets/2009/04

我该怎么做?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2009-04-24 18:28:19

将一些命名范围添加到您的Target模型中,以支持按年和按月份进行查找。类似于:

代码语言:javascript
运行
复制
class Target < ActiveRecord::Base
  named_scope :by_month,
    lambda { |month| { :conditions => ['MONTH(recorded_on) = ?',
                        month] }}

  named_scope :by_year,
    lambda { |year| { :conditions => ['YEAR(recorded_on) = ?', year] }} 
  .
  .
  .
end

(请注意这里的条件使用的是MySQL语法。)

假设您使用的是RESTful路由,那么在您的config/routes.rb文件中设置一个命名路由 (确保它在默认路由之前声明):

代码语言:javascript
运行
复制
map.targets_by_month '/targets/:year/:month', :controller => 'targets',
                :requirements => { :year => /\d{4}/, :month => /\d{1,2}/ },
                :conditions => { :method => :get }

-You可以在视图中使用此路由,如下所示:

代码语言:javascript
运行
复制
<%= link_to 'Show April 2009 Targets', targets_by_month_path('2009', '04') %>

(注意,这个月的前导零是可选的,因为上面定义的命名路由中有:requirements正则表达式)

最后,在您的TargetsController中,设置index操作以使用前面定义的named_scopes:

代码语言:javascript
运行
复制
def index
  @records = Target.by_year(params[:year]).by_month(params[:month])
  .
  .
  .
end
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/786948

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档