method
configure_connection
v5.1.7 -
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 717
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 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/current/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?
- arel_visitor
- clear_cache!
- column_name_for_operation
- default_index_type?
- disable_extension
- disconnect!
- enable_extension
- extension_enabled?
- extensions
- get_advisory_lock
- index_algorithms
- index_name_length
- max_identifier_length
- native_database_types
- postgresql_version
- reconnect!
- release_advisory_lock
- reset!
- schema_creation
- session_auth=
- set_standard_conforming_strings
- supports_advisory_locks?
- supports_comments?
- supports_datetime_with_precision?
- supports_ddl_transactions?
- supports_explain?
- supports_expression_index?
- supports_extensions?
- supports_foreign_keys?
- supports_index_sort_order?
- supports_json?
- supports_materialized_views?
- supports_partial_index?
- supports_pgcrypto_uuid?
- supports_ranges?
- supports_savepoints?
- supports_statement_cache?
- supports_transaction_isolation?
- supports_views?
- table_alias_length
- truncate
- update_table_definition
- use_insert_returning?
- Class methods
- new
- Private methods
-
add_pg_decoders -
add_pg_encoders -
can_perform_case_insensitive_comparison_for? -
column_definitions -
configure_connection -
connect -
construct_coder -
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? -
in_transaction? -
initialize_type_map -
is_cached_plan_failure? -
last_insert_id_result -
load_additional_types -
prepare_statement -
sql_key -
translate_exception