Сначала убедитесь, что ваши отношения настроены следующим образом:
class Ad < ActiveRecord::Base
belongs_to :ad_group, inverse_of: :ads
end
class AdGroup < ActiveRecord::Base
belongs_to :campaign, inverse_of: :ad_groups
has_many :ads, inverse_of :ad_group
end
class Campaign < ActiveRecord::Base
belongs_to :client, inverse_of: :campaigns
has_many :ad_groups, inverse_of :campaign
end
class Client < ActiveRecord::Base
has_many :campaigns, inverse_of :client
end
Используйте соединения и собирайте, если вам нужен только идентификатор клиента и эффективный SQL:
Client.joins(campaigns: {ad_groups: :ad}).where(
ads: { id: some_id }).pluck('clients.id').first
Если вам нужен весь клиент и эффективный SQL, просто:
Client.joins(campaigns: {ad_groups: :ad}).where(ads: { id: some_id }).first