Class: ActiveRecord::ConnectionAdapters::OracleEnhancedColumn

Inherits:
Column
  • Object
show all
Defined in:
lib/active_record/connection_adapters/oracle_enhanced_adapter.rb

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(name, default, sql_type = nil, null = true, table_name = nil, forced_column_type = nil, virtual = false) ⇒ OracleEnhancedColumn

:nodoc:



190
191
192
193
194
195
# File 'lib/active_record/connection_adapters/oracle_enhanced_adapter.rb', line 190

def initialize(name, default, sql_type = nil, null = true, table_name = nil, forced_column_type = nil, virtual=false) #:nodoc:
  @table_name = table_name
  @forced_column_type = forced_column_type
  @virtual = virtual
  super(name, default, sql_type, null)
end

Instance Attribute Details

#forced_column_typeObject (readonly)

:nodoc:



188
189
190
# File 'lib/active_record/connection_adapters/oracle_enhanced_adapter.rb', line 188

def forced_column_type
  @forced_column_type
end

#table_nameObject (readonly)

:nodoc:



188
189
190
# File 'lib/active_record/connection_adapters/oracle_enhanced_adapter.rb', line 188

def table_name
  @table_name
end

Class Method Details

.string_to_date(string) ⇒ Object

convert Time or DateTime value to Date for :date columns



220
221
222
223
# File 'lib/active_record/connection_adapters/oracle_enhanced_adapter.rb', line 220

def self.string_to_date(string) #:nodoc:
  return string.to_date if string.is_a?(Time) || string.is_a?(DateTime)
  super
end

.string_to_time(string) ⇒ Object

convert Date value to Time for :datetime columns



226
227
228
229
# File 'lib/active_record/connection_adapters/oracle_enhanced_adapter.rb', line 226

def self.string_to_time(string) #:nodoc:
  return string.to_time if string.is_a?(Date) && !OracleEnhancedAdapter.emulate_dates
  super
end

.value_to_boolean(value) ⇒ Object

convert something to a boolean added y as boolean value



209
210
211
212
213
214
215
216
217
# File 'lib/active_record/connection_adapters/oracle_enhanced_adapter.rb', line 209

def self.value_to_boolean(value) #:nodoc:
  if value == true || value == false
    value
  elsif value.is_a?(String) && value.blank?
    nil
  else
    %w(true t 1 y +).include?(value.to_s.downcase)
  end
end

Instance Method Details

#commentObject

Get column comment from schema definition. Will work only if using default ActiveRecord connection.



233
234
235
# File 'lib/active_record/connection_adapters/oracle_enhanced_adapter.rb', line 233

def comment
  ActiveRecord::Base.connection.column_comment(@table_name, name)
end

#type_cast(value) ⇒ Object

:nodoc:



197
198
199
200
201
# File 'lib/active_record/connection_adapters/oracle_enhanced_adapter.rb', line 197

def type_cast(value) #:nodoc:
  return value if self.virtual?
  return guess_date_or_time(value) if type == :datetime && OracleEnhancedAdapter.emulate_dates
  super
end

#virtual?Boolean

Returns:

  • (Boolean)


203
204
205
# File 'lib/active_record/connection_adapters/oracle_enhanced_adapter.rb', line 203

def virtual?
  @virtual
end