diff options
author | Paul Johnston <paj@pajhome.org.uk> | 2007-11-25 23:34:39 +0000 |
---|---|---|
committer | Paul Johnston <paj@pajhome.org.uk> | 2007-11-25 23:34:39 +0000 |
commit | 2c873f0ee45db04cb880de7c24b56564eb9605a4 (patch) | |
tree | f1fae8cf4c2cd36834685b4794b72e469303704f /lib/sqlalchemy/databases/mssql.py | |
parent | 37bffd8f2b6c3b4419d6e9317bc097d52124360d (diff) | |
download | sqlalchemy-2c873f0ee45db04cb880de7c24b56564eb9605a4.tar.gz |
Fix: test_decimal on MSSQL - use a value that is accurately represented as a float, and make when asdecimal=False, convert Decimal to float
Diffstat (limited to 'lib/sqlalchemy/databases/mssql.py')
-rw-r--r-- | lib/sqlalchemy/databases/mssql.py | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/lib/sqlalchemy/databases/mssql.py b/lib/sqlalchemy/databases/mssql.py index a1cefb019..d060458d4 100644 --- a/lib/sqlalchemy/databases/mssql.py +++ b/lib/sqlalchemy/databases/mssql.py @@ -43,12 +43,23 @@ from sqlalchemy import sql, schema, exceptions, util from sqlalchemy.sql import compiler, expression, operators as sqlops from sqlalchemy.engine import default, base from sqlalchemy import types as sqltypes +from sqlalchemy.util import Decimal as _python_Decimal MSSQL_RESERVED_WORDS = util.Set(['function']) class MSNumeric(sqltypes.Numeric): def result_processor(self, dialect): - return None + if self.asdecimal: + def process(value): + if value is not None: + return _python_Decimal(str(value)) + else: + return value + return process + else: + def process(value): + return float(value) + return process def bind_processor(self, dialect): def process(value): |