Active Record MySQL2 适配器
方法
- A
- D
- E
- N
- Q
- S
包含的模块
常量
ADAPTER_NAME | = | "Mysql2" |
ER_ACCESS_DENIED_ERROR | = | 1045 |
ER_BAD_DB_ERROR | = | 1049 |
ER_CONN_HOST_ERROR | = | 2003 |
ER_DBACCESS_DENIED_ERROR | = | 1044 |
ER_UNKNOWN_HOST_ERROR | = | 2005 |
TYPE_MAP | = | Type::TypeMap.new.tap { |m| initialize_type_map(m) } |
类公有方法
new(...) 链接
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 66 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
new_client(config) 链接
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 35 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
实例公有方法
active?() 链接
disconnect!() 链接
如果已连接,则断开与数据库的连接。否则,此方法不执行任何操作。
源代码:显示 | 在 GitHub 上
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 141 def disconnect! super @raw_connection&.close @raw_connection = nil end
error_number(exception) 链接
源代码:显示 | 在 GitHub 上
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 114 def error_number(exception) exception.error_number if exception.respond_to?(:error_number) end
quote_string(string) 链接
引用字符串以用于 SQL 输入。
源代码:显示 | 在 GitHub 上
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 123 def quote_string(string) with_raw_connection(allow_retry: true, materialize_transactions: false) do |connection| connection.escape(string) end end
savepoint_errors_invalidate_transactions?() 链接
源代码:显示 | 在 GitHub 上
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 96 def savepoint_errors_invalidate_transactions? true end
supports_comments?() 链接
源代码:显示 | 在 GitHub 上
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 84 def supports_comments? true end
supports_comments_in_create?() 链接
源代码:显示 | 在 GitHub 上
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 88 def supports_comments_in_create? true end
supports_json?() 链接
源代码:显示 | 在 GitHub 上
# File activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb, line 80 def supports_json? !mariadb? && database_version >= "5.7.8" end