0
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.... 这可能是不同的协议。

4

1 回答 1

0

我不确定这是否正是您所需要的,但希望它会是:

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)

我希望这有帮助。

于 2013-02-25T18:15:34.077 回答