- F
- Q
- T
- U
# File activerecord/lib/active_record/connection_adapters/abstract/quoting.rb, line 71 def fetch_type_metadata(sql_type) cast_type = lookup_cast_type(sql_type) SqlTypeMetadata.new( sql_type: sql_type, type: cast_type.type, limit: cast_type.limit, precision: cast_type.precision, scale: cast_type.scale, ) end
Quotes the column value to help prevent SQL injection attacks.
# File activerecord/lib/active_record/connection_adapters/abstract/quoting.rb, line 9 def quote(value) value = id_value_for_database(value) if value.is_a?(Base) if value.respond_to?(:quoted_id) at = value.method(:quoted_id).source_location at &&= " at %s:%d" % at owner = value.method(:quoted_id).owner.to_s klass = value.class.to_s klass += "(#{owner})" unless owner == klass ActiveSupport::Deprecation.warn "Defining #quoted_id is deprecated and will be ignored in Rails 5.2. (defined on #{klass}#{at})" return value.quoted_id end _quote(value) end
Quotes the column name. Defaults to no quoting.
Quotes a string, escaping any ' (single quote) and \ (backslash) characters.
Quotes the table name. Defaults to column name quoting.
Override to return the quoted table name for assignment. Defaults to table quoting.
This works for mysql2 where table.column can be used to resolve ambiguity.
We override this in the sqlite3 and postgresql adapters to use only the column name (as per syntax requirements).
Quote date/time values for use in SQL input. Includes microseconds if the value is a Time responding to usec.
# File activerecord/lib/active_record/connection_adapters/abstract/quoting.rb, line 137 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 end result = value.to_s(:db) if value.respond_to?(:usec) && value.usec > 0 "#{result}.#{sprintf("%06d", value.usec)}" else result end end
Cast a value
to a type that the database understands. For
example, SQLite does not understand dates, so this method will convert a Date to a String.
# File activerecord/lib/active_record/connection_adapters/abstract/quoting.rb, line 31 def type_cast(value, column = nil) value = id_value_for_database(value) if value.is_a?(Base) if value.respond_to?(:quoted_id) && value.respond_to?(:id) return value.id end if column value = type_cast_from_column(column, value) end _type_cast(value) rescue TypeError to_type = column ? " to #{column.type}" : "" raise TypeError, "can't cast #{value.class}#{to_type}" end