Query for has_many through rails

帅比萌擦擦* 提交于 2019-12-12 02:54:23

问题


Association is

class Campaign
  has_many :views_logs
  has_many :users, through: :views_logs
end

I want to get all users in a Campaign within any specific dates etc meaning, I want to do something like: Campaign.first.users.where(?)

Now, when I query:

Campaign.first.users.all

I get list of all users within a certain campaign, but how I can I get only those users which have Campaign between specific date ranges only.


回答1:


I want to get all users in a Campaign within any specific dates

ActiveRecord Association Extension:

#app/models/campaign.rb
class Campaign < ActiveRecord::Base
   has_many :users, through: :view_logs do
      def between start_date, end_date
         where(created_at: start_date..end_date)
      end
   end
end

@campaign = Campaign.find x
@users    = @campaign.users.between(Date.today - 2, Date.today.day)

--

Update - it seems PGSQL requires a timestamp to evaluate dates:

@users = @campaign.users.between(Time.now.midnight - 2.days, Time.now.midnight)

The difference being that between Date & Time objects.




回答2:


Simply define a scope in User like this:

class User < ActiveRecord::Base
  # Your current code
  scope :during_campaign, -> (start, end) { 
       joins(view_logs: :campaign).where('campaigns.created_at >= ? AND campaigns.created_at <= ?', start, end)
  }

end

Then use it:

# User from yesterday compaign for eg
User.during_campaign(1.day.ago, Time.now)

Make it generic & pretty always!




回答3:


Have you tried doing:

Campaign.first.users.where("campaigns.created_at > #{start_date} AND campaigns.created_at < #{end_date}")


来源:https://stackoverflow.com/questions/35125607/query-for-has-many-through-rails

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!