Sha256: 5549a544ff2fef63a66fcf4cf1b5f23ef606fd0534e9af8d3a2956fa419a5834
Contents?: true
Size: 1.25 KB
Versions: 6
Compression:
Stored size: 1.25 KB
Contents
--- title: Polymorphic Searches sidebar_position: 14 --- When making searches from polymorphic models it is necessary to specify the type of model you are searching. For example: Given two models ```ruby class House < ActiveRecord::Base has_one :location, as: :locatable end class Location < ActiveRecord::Base belongs_to :locatable, polymorphic: true end ``` Normally (without polymorphic relationship) you would be able to search as per below: ```ruby Location.ransack(locatable_number_eq: 100).result ``` However when this is searched you will get the following error ```ruby ActiveRecord::EagerLoadPolymorphicError: Can not eagerly load the polymorphic association :locatable ``` In order to search for locations by house number when the relationship is polymorphic you have to specify the type of records you will be searching and construct your search as below: ```ruby Location.ransack(locatable_of_House_type_number_eq: 100).result ``` note the `_of_House_type_` added to the search key. This allows Ransack to correctly specify the table names in SQL join queries. For namespaced models you should use a quoted string containing the standard Ruby module notation ```ruby Location.ransack('locatable_of_Residences::House_type_number_eq' => 100).result ```
Version data entries
6 entries across 5 versions & 2 rubygems