class ScopedSearch::QueryBuilder::PostgreSQLAdapter
The PostgreSQLAdapter
make sure that searches are case sensitive when using the like/unlike operators, by using the PostrgeSQL-specific ILIKE operator
instead of LIKE
.
Public Instance Methods
order_by(order, &block)
click to toggle source
Calls superclass method
ScopedSearch::QueryBuilder#order_by
# File lib/scoped_search/query_builder.rb 590 def order_by(order, &block) 591 sql = super(order, &block) 592 if sql 593 field, _ = find_field_for_order_by(order, &block) 594 sql += sql.include?('DESC') ? ' NULLS LAST ' : ' NULLS FIRST ' if !field.nil? && field.column.null 595 end 596 sql 597 end
sql_operator(operator, field)
click to toggle source
Switches out the default LIKE operator in the default sql_operator
method for ILIKE or @@ if full text searching is enabled.
Calls superclass method
ScopedSearch::QueryBuilder#sql_operator
# File lib/scoped_search/query_builder.rb 575 def sql_operator(operator, field) 576 raise ScopedSearch::QueryNotSupported, "the operator '#{operator}' is not supported for field type '#{field.type}'" if !field.virtual? and [:like, :unlike].include?(operator) and !field.textual? 577 return '@@' if [:like, :unlike].include?(operator) && field.full_text_search 578 case operator 579 when :like then 'ILIKE' 580 when :unlike then 'NOT ILIKE' 581 else super(operator, field) 582 end 583 end
sql_test(field, operator, value, lhs) { |:parameter, value| ... }
click to toggle source
Switches out the default query generation of the sql_test
method if full text searching is enabled and a text search is being performed.
Calls superclass method
ScopedSearch::QueryBuilder#sql_test
# File lib/scoped_search/query_builder.rb 562 def sql_test(field, operator, value, lhs, &block) 563 if [:like, :unlike].include?(operator) && field.full_text_search 564 yield(:parameter, value) 565 negation = (operator == :unlike) ? "NOT " : "" 566 locale = (field.full_text_search == true) ? 'english' : field.full_text_search 567 return "#{negation}to_tsvector('#{locale}', #{field.to_sql(operator, &block)}) #{self.sql_operator(operator, field)} to_tsquery('#{locale}', ?)" 568 else 569 super 570 end 571 end
to_not_sql(rhs, definition, &block)
click to toggle source
Returns a NOT (…) SQL fragment that negates the current AST
node's children
# File lib/scoped_search/query_builder.rb 586 def to_not_sql(rhs, definition, &block) 587 "NOT COALESCE(#{rhs.to_sql(self, definition, &block)}, false)" 588 end