diff options
| author | Mike Bayer <mike_mp@zzzcomputing.com> | 2007-12-18 06:13:42 +0000 |
|---|---|---|
| committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2007-12-18 06:13:42 +0000 |
| commit | df68f307775a545e067f3a8a3f6bcc9e1f11d9b2 (patch) | |
| tree | a0405894532079a4fdda9d1a7a840ce212b8c6be /lib/sqlalchemy | |
| parent | faf4aca165cef9bbd8d90b7a4f4ccf2b3d986ea1 (diff) | |
| download | sqlalchemy-df68f307775a545e067f3a8a3f6bcc9e1f11d9b2.tar.gz | |
get most oracle tests in sql working again....
Diffstat (limited to 'lib/sqlalchemy')
| -rw-r--r-- | lib/sqlalchemy/engine/base.py | 13 | ||||
| -rw-r--r-- | lib/sqlalchemy/sql/compiler.py | 1 | ||||
| -rw-r--r-- | lib/sqlalchemy/sql/functions.py | 5 |
3 files changed, 16 insertions, 3 deletions
diff --git a/lib/sqlalchemy/engine/base.py b/lib/sqlalchemy/engine/base.py index 3219e6c5b..783d60cf4 100644 --- a/lib/sqlalchemy/engine/base.py +++ b/lib/sqlalchemy/engine/base.py @@ -1656,8 +1656,17 @@ class BufferedColumnResultProxy(ResultProxy): _process_row = BufferedColumnRow def _get_col(self, row, key): - rec = self._key_cache[key] - return row[rec[2]] + try: + rec = self._key_cache[key] + return row[rec[2]] + except TypeError: + # the 'slice' use case is very infrequent, + # so we use an exception catch to reduce conditionals in _get_col + if isinstance(key, slice): + indices = key.indices(len(row)) + return tuple([self._get_col(row, i) for i in xrange(*indices)]) + else: + raise def fetchall(self): l = [] diff --git a/lib/sqlalchemy/sql/compiler.py b/lib/sqlalchemy/sql/compiler.py index 30b4089d3..247285384 100644 --- a/lib/sqlalchemy/sql/compiler.py +++ b/lib/sqlalchemy/sql/compiler.py @@ -90,6 +90,7 @@ FUNCTIONS = { functions.current_user: 'CURRENT_USER', functions.localtime: 'LOCALTIME', functions.localtimestamp: 'LOCALTIMESTAMP', + functions.sysdate: 'sysdate', functions.session_user :'SESSION_USER', functions.user: 'USER' } diff --git a/lib/sqlalchemy/sql/functions.py b/lib/sqlalchemy/sql/functions.py index d39032b91..869df46a7 100644 --- a/lib/sqlalchemy/sql/functions.py +++ b/lib/sqlalchemy/sql/functions.py @@ -67,6 +67,9 @@ class localtimestamp(AnsiFunction): class session_user(AnsiFunction): __return_type__ = sqltypes.String +class sysdate(AnsiFunction): + __return_type__ = sqltypes.DateTime + class user(AnsiFunction): __return_type__ = sqltypes.String @@ -75,4 +78,4 @@ def _type_from_args(args): if not isinstance(a.type, sqltypes.NullType): return a.type else: - return sqltypes.NullType
\ No newline at end of file + return sqltypes.NullType |
