method
configure_connection
v4.2.1 -
Show latest stable
- Class:
ActiveRecord::ConnectionAdapters::PostgreSQLAdapter
configure_connection()private
Configures the encoding, verbosity, schema search path, and time zone of the connection. This is called by #connect and should not be called manually.
# File activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb, line 669
def configure_connection
if @config[:encoding]
@connection.set_client_encoding(@config[:encoding])
end
self.client_min_messages = @config[:min_messages] || 'warning'
self.schema_search_path = @config[:schema_search_path] || @config[:schema_order]
# Use standard-conforming strings if available so we don't have to do the E'...' dance.
set_standard_conforming_strings
# If using Active Record's time zone support configure the connection to return
# TIMESTAMP WITH ZONE types in UTC.
# (SET TIME ZONE does not use an equals sign like other SET variables)
if ActiveRecord::Base.default_timezone == :utc
execute("SET time zone 'UTC'", 'SCHEMA')
elsif @local_tz
execute("SET time zone '#{@local_tz}'", 'SCHEMA')
end
# SET statements from :variables config hash
# http://www.postgresql.org/docs/8.3/static/sql-set.html
variables = @config[:variables] || {}
variables.map do |k, v|
if v == ':default' || v == :default
# Sets the value to the global or compile default
execute("SET SESSION #{k} TO DEFAULT", 'SCHEMA')
elsif !v.nil?
execute("SET SESSION #{k} TO #{quote(v)}", 'SCHEMA')
end
end
end Related methods
- Instance methods
- active?
- clear_cache!
- column_name_for_operation
- disable_extension
- disconnect!
- enable_extension
- extension_enabled?
- extensions
- index_algorithms
- lookup_cast_type
- migration_keys
- native_database_types
- prepare_column_options
- reconnect!
- reset!
- schema_creation
- session_auth=
- set_standard_conforming_strings
- supports_ddl_transactions?
- supports_explain?
- supports_extensions?
- supports_foreign_keys?
- supports_index_sort_order?
- supports_materialized_views?
- supports_migrations?
- supports_partial_index?
- supports_primary_key?
- supports_ranges?
- supports_statement_cache?
- supports_transaction_isolation?
- supports_views?
- table_alias_length
- truncate
- update_table_definition
- use_insert_returning?
- valid_type?
- Class methods
- new
- Protected methods
-
postgresql_version -
translate_exception - Private methods
-
column_definitions -
configure_connection -
connect -
create_table_definition -
exec_cache -
exec_no_cache -
execute_and_clear -
extract_default_function -
extract_limit -
extract_table_ref_from_insert_sql -
extract_value_from_default -
get_oid_type -
has_default_function? -
initialize_type_map -
last_insert_id -
last_insert_id_result -
last_insert_id_value -
load_additional_types -
prepare_statement -
sql_key