summaryrefslogtreecommitdiff
path: root/lib/sqlalchemy/databases/mssql.py
diff options
context:
space:
mode:
authorPaul Johnston <paj@pajhome.org.uk>2007-11-25 23:34:39 +0000
committerPaul Johnston <paj@pajhome.org.uk>2007-11-25 23:34:39 +0000
commit2c873f0ee45db04cb880de7c24b56564eb9605a4 (patch)
treef1fae8cf4c2cd36834685b4794b72e469303704f /lib/sqlalchemy/databases/mssql.py
parent37bffd8f2b6c3b4419d6e9317bc097d52124360d (diff)
downloadsqlalchemy-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.py13
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):