22 lines
		
	
	
		
			795 B
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			22 lines
		
	
	
		
			795 B
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| # == Schema Information
 | |
| #
 | |
| # Table name: status_trends
 | |
| #
 | |
| #  id         :bigint(8)        not null, primary key
 | |
| #  status_id  :bigint(8)        not null
 | |
| #  account_id :bigint(8)        not null
 | |
| #  score      :float            default(0.0), not null
 | |
| #  rank       :integer          default(0), not null
 | |
| #  allowed    :boolean          default(FALSE), not null
 | |
| #  language   :string
 | |
| #
 | |
| 
 | |
| class StatusTrend < ApplicationRecord
 | |
|   belongs_to :status
 | |
|   belongs_to :account
 | |
| 
 | |
|   scope :allowed, -> { joins('INNER JOIN (SELECT account_id, MAX(score) AS max_score FROM status_trends GROUP BY account_id) AS grouped_status_trends ON status_trends.account_id = grouped_status_trends.account_id AND status_trends.score = grouped_status_trends.max_score').where(allowed: true) }
 | |
| end
 |