Solved

rails 3 group_by for simple active record groupings

Posted on 2010-11-21
3
1,073 Views
Last Modified: 2012-08-14
so i have fixtures that have different seasons, i want to group and display the fixtures by season. On the fixtures index page i want the current season displayed and then link to old seasons. I was thinks some kind of group_by method?
class FixturesController < ApplicationController
 
  def index
    @fixtures = Fixture.all
  end
end

##view
<h1>Listing fixtures</h1>

<% @fixtures.each do |fixture| %>
  <%= fixture.season.title %></td>
  <td><%= fixture.event.title %></td>
  <td><%= fixture.home_team.name %></td>
  <td><%= fixture.away_team.name %></td>
  <td><%= fixture.date %></td>

class Season < ActiveRecord::Base
  has_many :fixtures
end

class Fixture < ActiveRecord::Base
  belongs_to :season
  belongs_to :event
  belongs_to :home_team, :class_name => 'Team'
  belongs_to :away_team, :class_name => 'Team'
end

Open in new window

0
Comment
Question by:depassion
  • 2
3 Comments
 
LVL 2

Expert Comment

by:lusfernandos
ID: 34425381
I don't know how you are getting the @fixtures in your index action ... anyway I believe you just need to order by season
something like:

@fixtures = Fixture.all(:order=>"season_id ASC")
0
 

Accepted Solution

by:
depassion earned 0 total points
ID: 34426260
i"ve solved it by creating a get_season method which works out the current season.
#application_controller
before_filter :get_season

def get_season
    @current_season = Season.where(["start_date < ? AND end_date > ?", Date.today, Date.today]).first
  end


#fixtures_view
<% @current_season.fixtures.each do |fixture| %>
...
<%end%>

Open in new window

0
 

Author Closing Comment

by:depassion
ID: 34447401
took too long for a solution from the community so was forced to pay to get help
0

Featured Post

Master Your Team's Linux and Cloud Stack!

The average business loses $13.5M per year to ineffective training (per 1,000 employees). Keep ahead of the competition and combine in-person quality with online cost and flexibility by training with Linux Academy.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Article by: narshlob
If you've ever programmed in Ruby and have come across either a proc or a lambda, you might have been wondering what the difference is between the two and when you would use one over the other. This article will try to explain the difference between…
Recently I spent hours debugging an issue in a Rails project where ActiveRecord was causing MySQL errors trying to create a User object of a class at the top level of a Single Table Inheritance model structure.  It turns out `.create` behaves differ…
This Micro Tutorial will teach you how to censor certain areas of your screen. The example in this video will show a little boy's face being blurred. This will be demonstrated using Adobe Premiere Pro CS6.
Although Jacob Bernoulli (1654-1705) has been credited as the creator of "Binomial Distribution Table", Gottfried Leibniz (1646-1716) did his dissertation on the subject in 1666; Leibniz you may recall is the co-inventor of "Calculus" and beat Isaac…

803 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question