Methods
- active?
- database_exists?
- disconnect!
- error_number
- new
- new_client
- quote_string
- reconnect!
- reset!
- supports_comments?
- supports_comments_in_create?
- supports_json?
- supports_lazy_transactions?
- supports_savepoints?
Included Modules
Constants
ADAPTER_NAME | = | "Mysql2" |
ER_ACCESS_DENIED_ERROR | = | 1045 |
ER_BAD_DB_ERROR | = | 1049 |
ER_CONN_HOST_ERROR | = | 2003 |
ER_UNKNOWN_HOST_ERROR | = | 2005 |
Class Public methods
database_exists?(config)
📝 Source code
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 64
def self.database_exists?(config)
!!ActiveRecord::Base.mysql2_connection(config)
rescue ActiveRecord::NoDatabaseError
false
end
🔎 See on GitHub
new(connection, logger, connection_options, config)
📝 Source code
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 58
def initialize(connection, logger, connection_options, config)
superclass_config = config.reverse_merge(prepared_statements: false)
super(connection, logger, connection_options, superclass_config)
configure_connection
end
🔎 See on GitHub
new_client(config)
📝 Source code
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 43
def new_client(config)
Mysql2::Client.new(config)
rescue Mysql2::Error => error
if error.error_number == ConnectionAdapters::Mysql2Adapter::ER_BAD_DB_ERROR
raise ActiveRecord::NoDatabaseError.db_error(config[:database])
elsif error.error_number == ConnectionAdapters::Mysql2Adapter::ER_ACCESS_DENIED_ERROR
raise ActiveRecord::DatabaseConnectionError.username_error(config[:username])
elsif [ConnectionAdapters::Mysql2Adapter::ER_CONN_HOST_ERROR, ConnectionAdapters::Mysql2Adapter::ER_UNKNOWN_HOST_ERROR].include?(error.error_number)
raise ActiveRecord::DatabaseConnectionError.hostname_error(config[:host])
else
raise ActiveRecord::ConnectionNotEstablished, error.message
end
end
🔎 See on GitHub
Instance Public methods
active?()
📝 Source code
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 118
def active?
@connection.ping
end
🔎 See on GitHub
disconnect!()
Disconnects from the database if already connected. Otherwise, this method does nothing.
📝 Source code
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 131
def disconnect!
super
@connection.close
end
🔎 See on GitHub
error_number(exception)
📝 Source code
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 100
def error_number(exception)
exception.error_number if exception.respond_to?(:error_number)
end
🔎 See on GitHub
quote_string(string)
📝 Source code
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 108
def quote_string(string)
@connection.escape(string)
rescue Mysql2::Error => error
raise translate_exception(error, message: error.message, sql: "<escape>", binds: [])
end
🔎 See on GitHub
reconnect!()
Also aliased as: reset!
📝 Source code
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 122
def reconnect!
super
disconnect!
connect
end
🔎 See on GitHub
supports_comments?()
📝 Source code
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 74
def supports_comments?
true
end
🔎 See on GitHub
supports_comments_in_create?()
📝 Source code
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 78
def supports_comments_in_create?
true
end
🔎 See on GitHub
supports_json?()
📝 Source code
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 70
def supports_json?
!mariadb? && database_version >= "5.7.8"
end
🔎 See on GitHub
supports_lazy_transactions?()
📝 Source code
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 86
def supports_lazy_transactions?
true
end
🔎 See on GitHub
supports_savepoints?()
📝 Source code
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 82
def supports_savepoints?
true
end
🔎 See on GitHub