aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJeremy Kemper <jeremy@bitsweat.net>2005-11-15 15:58:36 +0000
committerJeremy Kemper <jeremy@bitsweat.net>2005-11-15 15:58:36 +0000
commitc98011bc32ac892f38bbda15b485c87a35795bba (patch)
treed233cb5059f04fb1922193ca9bd54b178dff17d0
parente7b65b590a386537fa17898aaba47d816c1ea215 (diff)
downloadrails-c98011bc32ac892f38bbda15b485c87a35795bba.tar.gz
rails-c98011bc32ac892f38bbda15b485c87a35795bba.tar.bz2
rails-c98011bc32ac892f38bbda15b485c87a35795bba.zip
SQLServer: active? and reconnect! methods for handling stale connections. References #428.
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@3045 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
-rw-r--r--activerecord/CHANGELOG2
-rw-r--r--activerecord/lib/active_record/connection_adapters/sqlserver_adapter.rb19
2 files changed, 9 insertions, 12 deletions
diff --git a/activerecord/CHANGELOG b/activerecord/CHANGELOG
index 55ba45904e..2557eeb98f 100644
--- a/activerecord/CHANGELOG
+++ b/activerecord/CHANGELOG
@@ -1,6 +1,6 @@
*SVN*
-* SQLServer: active? and reconnect! methods for handling stale connections. #428 [kajism@yahoo.com]
+* SQLServer: active? and reconnect! methods for handling stale connections. #428 [kajism@yahoo.com, Tom Ward <tom@popdog.net>]
* Associations handle case-equality more consistently: item.parts.is_a?(Array) and item.parts === Array. #1345 [MarkusQ@reality.com]
diff --git a/activerecord/lib/active_record/connection_adapters/sqlserver_adapter.rb b/activerecord/lib/active_record/connection_adapters/sqlserver_adapter.rb
index 78486a2a1a..9320717b34 100644
--- a/activerecord/lib/active_record/connection_adapters/sqlserver_adapter.rb
+++ b/activerecord/lib/active_record/connection_adapters/sqlserver_adapter.rb
@@ -207,24 +207,21 @@ module ActiveRecord
# Returns true if the connection is active.
def active?
- @connection.execute("SELECT 1") {|sth|}
+ @connection.execute("SELECT 1") { }
true
- rescue DBI::DatabaseError => e
+ rescue DBI::DatabaseError, DBI::InterfaceError
false
end
- # Reconnects to the database.
+ # Reconnects to the database, returns false if no connection could be made.
def reconnect!
- begin
- @connection.disconnect
- @connection = DBI.connect(*@connection_options)
- rescue DBI::DatabaseError => e
- @logger.warn "#{adapter_name} automatic reconnection failed: #{e.message}"
- end
+ @connection.disconnect rescue nil
+ @connection = DBI.connect(*@connection_options)
+ rescue DBI::DatabaseError => e
+ @logger.warn "#{adapter_name} reconnection failed: #{e.message}" if @logger
+ false
end
-
-
def select_all(sql, name = nil)
select(sql, name)
end