Как мне отсортировать свои записи по средней оценке?

У меня есть таблица заведений, которую я показываю на странице указателя площадок как частичную. У меня также есть таблица отзывов, где одно место может иметь много отзывов, и каждый отзыв имеет рейтинг от 1 до 5.

Я ' показывает частичку места проведения в верхней части список.

  • Если объект 2 получил оценку 5 звезд и 1 звездочный обзор показывает два частичные, одна вверху и одна
    внизу списка.

  • Если объекту 3 присвоен 5-звездочный отзыв, 3-звездочный отзыв и 1 звездочный обзор показывает три частичные, одна вверху, одна посередине и одна внизу списка.

  • Мне просто нужно одно частичное представление для каждого места, но я позиционируюсь в списке по среднему рейтингу, я чувствую, что где-то отсутствует среднее значение или чего-то еще, как я могу этого добиться?

    Спасибо за все

    редактировать

    Модель объекта

    class Venue < ActiveRecord::Base
      attr_accessible :name, :addressline1, :addressline2, :addressline3, :addressline4, :postcode, :phonenumber, :about, :icontoppx, :iconleftpx, :area_id, :venuetype_id, :lat, :long, :venuephotos_attributes
      belongs_to :area
      belongs_to :venuetype
      has_many :reviews
      has_many :venuephotos
    
      accepts_nested_attributes_for :venuephotos, :allow_destroy => true
    
      scope :with_type, lambda { |types|
        types.present? ? where(:venuetype_id => types) : scoped }
    
      scope :with_area, lambda { |areas|
        areas.present? ? where(:area_id => areas) : scoped }
    
      def to_param
        "#{id}-#{name.gsub(/\W/, '-').downcase}"
      end
    
      def add_rating(rating_opts)
        @venue.add_rating(:rating => rating, :reviewer => params[:rating][:reviewer])
        self.reviews.create(rating_opts)
        self.update_rating!
      end
    
      def update_rating!
        s = self.reviews.sum(:rating)
        c = self.reviews.count
        self.update_attribute(:average_rating, s.to_f / c.to_f)
        self.save(:validate => false)
      end
    end
    

    Журнал разработки для добавления обзора

    Started POST "/venues/44-rating-test-5/reviews" for 127.0.0.1 at 2011-05-18 09:24:24 +0100
      Processing by ReviewsController#create as JS
      Parameters: {"utf8"=>"✓", "authenticity_token"=>"GZWd67b5ocJOjwKI6z9nJInBXxvQahHrjUtUpdm9oJE=", "review"=>{"rating"=>"5", "title"=>"5 star review"}, "venue_id"=>"44-rating-test-5"}
      [1m[36mVenue Load (1.0ms)[0m  [1mSELECT `venues`.* FROM `venues` WHERE (`venues`.`id` = 44) LIMIT 1[0m
      [1m[35mUser Load (0.0ms)[0m  SELECT `users`.* FROM `users` WHERE (`users`.`id` = 3) LIMIT 1
      [1m[36mSQL (0.0ms)[0m  [1mBEGIN[0m
      [1m[35mSQL (2.0ms)[0m  describe `reviews`
      [1m[36mAREL (0.0ms)[0m  [1mINSERT INTO `reviews` (`title`, `created_at`, `updated_at`, `venue_id`, `user_id`, `rating`) VALUES ('5 star review', '2011-05-18 08:24:24', '2011-05-18 08:24:24', NULL, 3, 5)[0m
      [1m[35mSQL (27.0ms)[0m  COMMIT
      [1m[36mSQL (0.0ms)[0m  [1mBEGIN[0m
      [1m[35mAREL (0.0ms)[0m  UPDATE `reviews` SET `venue_id` = 44, `updated_at` = '2011-05-18 08:24:24' WHERE (`reviews`.`id` = 90)
      [1m[36mSQL (23.0ms)[0m  [1mCOMMIT[0m
      [1m[35mSQL (1.0ms)[0m  SELECT COUNT(*) FROM `reviews` WHERE (`reviews`.venue_id = 44)
      [1m[36mUser Load (0.0ms)[0m  [1mSELECT `users`.* FROM `users` WHERE (`users`.`id` = 3) LIMIT 1[0m
    Rendered reviews/_review.html.erb (9.0ms)
    Rendered reviews/create.js.erb (22.0ms)
    Completed 200 OK in 220ms (Views: 56.0ms | ActiveRecord: 54.0ms)
    

    редактировать создать метод обзора (контроллер обзоров)

    def create
        @review = current_user.reviews.create!(params[:review])
        @review.venue = @venue
        if @review.save
          flash[:notice] = 'Thank you for reviewing this venue!'
          respond_to do |format|
            format.html { redirect_to venue_path(@venue) }
            format.js
          end
        else
          render :action => :new
        end
      end
    
    5
    задан Dave 19 May 2011 в 18:19
    поделиться