From 5f3cf4244de4fd62049d08df4e6bf63c945ab90e Mon Sep 17 00:00:00 2001 From: Aaron Patterson Date: Fri, 4 Feb 2011 10:19:02 -0800 Subject: connection pool can cache column, table, and primary key information --- .../abstract/connection_pool.rb | 34 ++++++++++++++++++++++ 1 file changed, 34 insertions(+) (limited to 'activerecord/lib') diff --git a/activerecord/lib/active_record/connection_adapters/abstract/connection_pool.rb b/activerecord/lib/active_record/connection_adapters/abstract/connection_pool.rb index 54f70c59f8..bafd79d614 100644 --- a/activerecord/lib/active_record/connection_adapters/abstract/connection_pool.rb +++ b/activerecord/lib/active_record/connection_adapters/abstract/connection_pool.rb @@ -58,6 +58,7 @@ module ActiveRecord # before giving up and raising a timeout error (default 5 seconds). class ConnectionPool attr_reader :spec, :connections + attr_reader :columns, :columns_hash, :primary_keys # Creates a new ConnectionPool object. +spec+ is a ConnectionSpecification # object which describes database connection information (e.g. adapter, @@ -81,6 +82,39 @@ module ActiveRecord @connections = [] @checked_out = [] + + @columns = Hash.new do |h, table_name| + h[table_name] = with_connection do |conn| + conn.columns(table_name, "#{table_name} Columns") + end + end + + @columns_hash = Hash.new do |h, table_name| + h[table_name] = Hash[columns[table_name].map { |col| + [col.name, col] + }] + end + + @primary_keys = Hash.new do |h, table_name| + h[table_name] = with_connection do |conn| + if conn.table_exists?(table_name) + conn.primary_key(table_name) + else + 'id' + end + end + end + end + + # Clears out internal caches: + # + # * columns + # * columns_hash + # * primary_keys + def clear_cache! + @columns.clear + @columns_hash.clear + @primary_keys.clear end # Retrieve the connection associated with the current thread, or call -- cgit v1.2.3