Как включить объединенную запись в результат с помощью squeel

st = 'pen'
ak = '123123'
agreements = Client.where{authentication_key == ak}.first.agreements
products = Product.joins{agreements}.where{agreements.id.in(a) & (short_description.like(st) | long_description.like( st))}

Я пытаюсь с выше, но мне нужно согласованное соглашение в моем результирующем наборе тоже ..

Из-за этого

class Product < ActiveRecord::Base
  has_and_belongs_to_many :agreements, uniq: true

Я не могу использовать products.first.agreement.first .... Это может быть другое соглашение.

0
nl ja de
Это наиболее близко: Product.joins {agreement} .where {agreement.id.in (a) & (short_description.like (st) | long_description.like (st))}. Select {[Agree.agreement_type, id]} Но вместо id я хочу все от продукта
добавлено автор Boti, источник

1 ответы

Я не уверен, что это именно то, что вам нужно, но, надеюсь, это будет:

client = Client.where { authentication_key == ak }.first
products = Client.agreements.joins { products }.where { (short_description.like(st) | long_description.like(st) }

Это возвращает продукты, связанные с соглашениями, которые, в свою очередь, связаны с вашим клиентом. Если вам нужно получить соглашения одного клиента для продукта, вы можете написать область действия:

class Product < ActiveRecord::Base
  #...
  def self.agreements_for_client(id)
    joins { agreements }.where { client_id.eq(id) }
  end
end

и вызов:

client = Client.where { authentication_key == ak }.first
Product.first.agreements_for_client(client.id)

Надеюсь, это поможет.

0
добавлено
pro.ruby
pro.ruby
1 181 участник(ов)

Язык программирования Ruby Additional docs: https://rubyreferences.github.io/rubyref/ Invite: https://telegram.me/joinchat/Be4rsT2NuB3CyJaF26j1kA Кто хочет компилировать: @crystal_ru (его синтаксис основан на Ruby) Участник @proDOT

Ruby, Rails, Hanami | dry-rb
Ruby, Rails, Hanami | dry-rb
1 180 участник(ов)

https://telegram.me/rubyjob - Ruby Job По вопросам - @eugene_shved

Ruby School .us
Ruby School .us
1 045 участник(ов)

Чат-болталка для учеников руби-школы и не только. Правила: https://telegra.ph/Pravila-chata-Rubi-shkoly-03-13

Random Ruby Chat
Random Ruby Chat
589 участник(ов)

Правила публикации вакансий: https://t.me/codenamecrud/60865

Rubyata
Rubyata
333 участник(ов)

Коммюнити Ruby и Ruby On Rails Флуд не приветствуются. Вакансии можно публиковать только и ТОЛЬКО по пятницам с хештегом #вакансия.

Ruby Talks
Ruby Talks
236 участник(ов)

Национальная Флеймотека

RubyRush
RubyRush
189 участник(ов)

rubyrush.ru программирование для самых новичков

Rails Chat
Rails Chat
87 участник(ов)

You are welcome to discuss Ruby On Rails development process and other stuff