class ActiveRecord::ConnectionAdapters::Mysql2Adapter
Active Record MySQL2 Adapter¶ ↑
Constants
- ADAPTER_NAME
- ER_ACCESS_DENIED_ERROR
- ER_BAD_DB_ERROR
- ER_CONN_HOST_ERROR
- ER_DBACCESS_DENIED_ERROR
- ER_UNKNOWN_HOST_ERROR
- TYPE_MAP
Public Class Methods
Calls superclass method
ActiveRecord::ConnectionAdapters::QueryCache::new
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 55 def initialize(...) super @config[:flags] ||= 0 if @config[:flags].kind_of? Array @config[:flags].push "FOUND_ROWS" else @config[:flags] |= ::Mysql2::Client::FOUND_ROWS end @connection_parameters ||= @config end
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 24 def new_client(config) ::Mysql2::Client.new(config) rescue ::Mysql2::Error => error case error.error_number when ER_BAD_DB_ERROR raise ActiveRecord::NoDatabaseError.db_error(config[:database]) when ER_DBACCESS_DENIED_ERROR, ER_ACCESS_DENIED_ERROR raise ActiveRecord::DatabaseConnectionError.username_error(config[:username]) when ER_CONN_HOST_ERROR, ER_UNKNOWN_HOST_ERROR raise ActiveRecord::DatabaseConnectionError.hostname_error(config[:host]) else raise ActiveRecord::ConnectionNotEstablished, error.message end end
Public Instance Methods
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 115 def active? connected? && @lock.synchronize { @raw_connection&.ping } || false end
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 111 def connected? !(@raw_connection.nil? || @raw_connection.closed?) end
Disconnects from the database if already connected. Otherwise, this method does nothing.
Calls superclass method
ActiveRecord::ConnectionAdapters::AbstractAdapter#disconnect!
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 123 def disconnect! @lock.synchronize do super @raw_connection&.close @raw_connection = nil end end
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 103 def error_number(exception) exception.error_number if exception.respond_to?(:error_number) end
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 85 def savepoint_errors_invalidate_transactions? true end
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 73 def supports_comments? true end
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 77 def supports_comments_in_create? true end
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 69 def supports_json? !mariadb? && database_version >= "5.7.8" end
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 89 def supports_lazy_transactions? true end
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 81 def supports_savepoints? true end