在我的Rails 4应用程序中,我有以下模型:
'AgencyGroup'
has_many :group_agencies
has_many :agencies, :through => :group_agencies
我在哪里保存“令牌”字段
代理商模式
has_many :group_agencies
has_many :agency_groups, :through => :group_agencies
has_many :advertisements
“广告”模式
belongs_to :agency
我使用了Think Sphinx,它的确很棒,但是现在我有了新的要求,可以按AgencyGroup令牌字段过滤“广告”。
基本上,我需要查找带有某些参数的广告,但仅适用于具有已发布令牌的代理商组中的代理商。
if params[:search]
@results = Advertisement.search Riddle::Query.escape(params[:search]), :star => true, :page => params[:page], :per_page => 6
end
为了获得结果,我像这样运行http查询:
http://api.localhost.local:3000/v1/advertisements?token=JHW_tdXn5g-vQY1f_ZzLuw&search=Nissim
我想念的是什么?如何在TS中使用模型之间的关系?
我认为这里最好的方法涉及几个步骤:
步骤1:在您的广告索引中添加AgencyGroup ID作为属性。如果您使用的是SQL支持的索引(:with => :active_record
),那么它是单行代码:
has agency.group_agencies.agency_group.id, :as => :agency_group_ids
如果您使用的是实时索引,那么您需要在Advertisement中使用一种方法来返回所有这些ID:
def agency_group_ids
agency.agency_group_ids
end
您的属性定义将如下所示:
has agency_group_ids, :type => :integer, :multi => true
第2步:因为您已经更改了索引结构,所以请不要忘记重建索引:
# for SQL-backed indices:
rake ts:rebuild
# or, for real-time indices
rake ts:regenerate
步骤3:在您的控制器中,找到给定令牌的代理商组:
agency_group = AgencyGroup.find_by :token => params[:token]
第4步:最后,在搜索电话中使用该代理商组的ID:
@results = Advertisement.search Riddle::Query.escape(params[:search]),
:star => true,
:page => params[:page],
:per_page => 6,
:with => {:agency_group_ids => agency_group.id}
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句