Sha256: 643bd8c19058f85f22e7d7c8d6406deaa4736b6e8599d73280e858eda206fefe

Contents?: true

Size: 1.29 KB

Versions: 3

Compression:

Stored size: 1.29 KB

Contents

module ODBCAdapter
  module Quoting
    # Quotes a string, escaping any ' (single quote) characters.
    def quote_string(string)
      string.gsub(/\'/, "''")
    end

    # Returns a quoted form of the column name.
    def quote_column_name(name)
      name = name.to_s
      quote_char = database_metadata.identifier_quote_char.to_s.strip

      return name if quote_char.length.zero?
      quote_char = quote_char[0]

      # Avoid quoting any already quoted name
      return name if name[0] == quote_char && name[-1] == quote_char

      # If upcase identifiers, only quote mixed case names.
      if database_metadata.upcase_identifiers?
        return name unless name =~ /([A-Z]+[a-z])|([a-z]+[A-Z])/
      end

      "#{quote_char.chr}#{name}#{quote_char.chr}"
    end

    # Ideally, we'd return an ODBC date or timestamp literal escape
    # sequence, but not all ODBC drivers support them.
    def quoted_date(value)
      if value.acts_like?(:time)
        zone_conversion_method = ActiveRecord::Base.default_timezone == :utc ? :getutc : :getlocal

        if value.respond_to?(zone_conversion_method)
          value = value.send(zone_conversion_method)
        end
        value.strftime('%Y-%m-%d %H:%M:%S') # Time, DateTime
      else
        value.strftime('%Y-%m-%d') # Date
      end
    end
  end
end

Version data entries

3 entries across 3 versions & 2 rubygems

Version Path
db2_odbc_adapter-0.0.1 lib/odbc_adapter/quoting.rb
odbc_adapter-5.0.5 lib/odbc_adapter/quoting.rb
odbc_adapter-5.0.3 lib/odbc_adapter/quoting.rb