Sha256: df4ddb8469b2c0d8e06258e2de1b5367392fec003114f83f2ef9a0add47bd820

Contents?: true

Size: 1.22 KB

Versions: 28

Compression:

Stored size: 1.22 KB

Contents

module ThinkingSphinx
  class MysqlAdapter < AbstractAdapter
    def setup
      # Does MySQL actually need to do anything?
    end
    
    def sphinx_identifier
      "mysql"
    end
    
    def concatenate(clause, separator = ' ')
      "CONCAT_WS('#{separator}', #{clause})"
    end
    
    def group_concatenate(clause, separator = ' ')
      "GROUP_CONCAT(DISTINCT IFNULL(#{clause}, '0') SEPARATOR '#{separator}')"
    end
    
    def cast_to_string(clause)
      "CAST(#{clause} AS CHAR)"
    end
    
    def cast_to_datetime(clause)
      "UNIX_TIMESTAMP(#{clause})"
    end
    
    def cast_to_unsigned(clause)
      "CAST(#{clause} AS UNSIGNED)"
    end
    
    def convert_nulls(clause, default = '')
      default = "'#{default}'" if default.is_a?(String)
      
      "IFNULL(#{clause}, #{default})"
    end
    
    def boolean(value)
      value ? 1 : 0
    end
    
    def crc(clause, blank_to_null = false)
      clause = "NULLIF(#{clause},'')" if blank_to_null
      "CRC32(#{clause})"
    end
    
    def utf8_query_pre
      "SET NAMES utf8"
    end
    
    def time_difference(diff)
      "DATE_SUB(NOW(), INTERVAL #{diff} SECOND)"
    end
    
    def utc_query_pre
      "SET TIME_ZONE = '+0:00'"
    end
  end
end

Version data entries

28 entries across 28 versions & 7 rubygems

Version Path
sayso-thinking-sphinx-2.0.3.002 lib/thinking_sphinx/adapters/mysql_adapter.rb
sayso-thinking-sphinx-2.0.3.001 lib/thinking_sphinx/adapters/mysql_adapter.rb
thinking-sphinx-2.0.4 lib/thinking_sphinx/adapters/mysql_adapter.rb
thinking-sphinx-1.4.5 lib/thinking_sphinx/adapters/mysql_adapter.rb
thinking-sphinx-2.0.3 lib/thinking_sphinx/adapters/mysql_adapter.rb
thinking-sphinx-1.4.4 lib/thinking_sphinx/adapters/mysql_adapter.rb
thinking-sphinx-1.4.3 lib/thinking_sphinx/adapters/mysql_adapter.rb
thinking-sphinx-2.0.2 lib/thinking_sphinx/adapters/mysql_adapter.rb
thinking-sphinx-1.4.2 lib/thinking_sphinx/adapters/mysql_adapter.rb
thinking-sphinx-1.4.1 lib/thinking_sphinx/adapters/mysql_adapter.rb
joshcutler-thinking-sphinx-1.3.18 lib/thinking_sphinx/adapters/mysql_adapter.rb
thinking-sphinx-2.0.1 lib/thinking_sphinx/adapters/mysql_adapter.rb
thinking-sphinx-2.0.0 lib/thinking_sphinx/adapters/mysql_adapter.rb
thinking-sphinx-1.4.0 lib/thinking_sphinx/adapters/mysql_adapter.rb
thorsson_thinking-sphinx-2.0 lib/thinking_sphinx/adapters/mysql_adapter.rb
angelf-thinking-sphinx-1.3.18 lib/thinking_sphinx/adapters/mysql_adapter.rb
thinking-sphinx-1.3.20 lib/thinking_sphinx/adapters/mysql_adapter.rb
thinking-sphinx-2.0.0.rc2 lib/thinking_sphinx/adapters/mysql_adapter.rb
thinking-sphinx-1.3.19 lib/thinking_sphinx/adapters/mysql_adapter.rb
thorsson_thinking-sphinx-1.3.18 lib/thinking_sphinx/adapters/mysql_adapter.rb