mam model Service
, ma zakres filtrowania usług według typu identyfikatorów usług:Myślenie Sphinx - wskaźnik do przyłączenia się do warunku (has_and_belongs_to_many)
class Service < ActiveRecord::Base
has_and_belongs_to_many :service_types
scope :by_service_types, -> ids { joins(:service_types).where('service_types_services.service_type_id in (?)', ids) }
end
class ServiceType < ActiveRecord::Base
has_and_belongs_to_many :services
end
tak, kiedy biegnę zakres, mam taki wynik :
Service.by_service_types([54])
Service Load (0.8ms) SELECT "services".* FROM "services" INNER JOIN "service_types_services" ON "service_types_services"."service_id" = "services"."id" INNER JOIN "service_types" ON "service_types"."id" = "service_types_services"."service_type_id" WHERE "services"."deleted" = 'f' AND (service_types_services.service_type_id in (54))
=> ...
Jak mogę zbudować atrybut do zbudowania indeksu dla takiego zakresu?