diff options
author | Hajime Nakagami <nakagami@gmail.com> | 2013-03-02 13:37:00 +0900 |
---|---|---|
committer | Hajime Nakagami <nakagami@gmail.com> | 2013-03-02 13:37:00 +0900 |
commit | 68c7827d695d1243a2344f450fc7762ba2faea57 (patch) | |
tree | 45bee1db48d09cdfe10512be407c5a51edf2d75d /lib/sqlalchemy/dialects/mysql/cymysql.py | |
parent | 979156c985d0c3992ae4127e0aa8b4c28ba97142 (diff) | |
download | sqlalchemy-68c7827d695d1243a2344f450fc7762ba2faea57.tar.gz |
is_disconnect() in cymysql dialect
Diffstat (limited to 'lib/sqlalchemy/dialects/mysql/cymysql.py')
-rw-r--r-- | lib/sqlalchemy/dialects/mysql/cymysql.py | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/lib/sqlalchemy/dialects/mysql/cymysql.py b/lib/sqlalchemy/dialects/mysql/cymysql.py index ddd9ac322..d9b43869c 100644 --- a/lib/sqlalchemy/dialects/mysql/cymysql.py +++ b/lib/sqlalchemy/dialects/mysql/cymysql.py @@ -58,4 +58,15 @@ class MySQLDialect_cymysql(MySQLDialect_mysqldb): def _extract_error_code(self, exception): return exception.errno + def is_disconnect(self, e, connection, cursor): + if isinstance(e, self.dbapi.OperationalError): + return self._extract_error_code(e) in \ + (2006, 2013, 2014, 2045, 2055) + elif isinstance(e, self.dbapi.InterfaceError): + # if underlying connection is closed, + # this is the error you get + return True + else: + return False + dialect = MySQLDialect_cymysql |