summaryrefslogtreecommitdiff
path: root/lib/sqlalchemy/dialects/oracle/base.py
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2018-05-23 16:22:48 -0400
committerMike Bayer <mike_mp@zzzcomputing.com>2018-05-25 10:29:10 -0400
commit6c27bf5048fc7335a1d1fdd49b651b1a164b8e32 (patch)
tree3b447956383f636fa42d343fe5d816ac196ef5bc /lib/sqlalchemy/dialects/oracle/base.py
parentc7ae04d1c5c4aa6c6099584ae386d6ab9ef7b290 (diff)
downloadsqlalchemy-6c27bf5048fc7335a1d1fdd49b651b1a164b8e32.tar.gz
Turn oracle BINARY_DOUBLE, BINARY_FLOAT, DOUBLE_PRECISION into floats
The Oracle BINARY_FLOAT and BINARY_DOUBLE datatypes now participate within cx_Oracle.setinputsizes(), passing along NATIVE_FLOAT, so as to support the NaN value. Additionally, :class:`.oracle.BINARY_FLOAT`, :class:`.oracle.BINARY_DOUBLE` and :class:`.oracle.DOUBLE_PRECISION` now subclass :class:`.Float`, since these are floating point datatypes, not decimal. These datatypes were already defaulting the :paramref:`.Float.asdecimal` flag to False in line with what :class:`.Float` already does. Added reflection capabilities for the :class:`.oracle.BINARY_FLOAT`, :class:`.oracle.BINARY_DOUBLE` datatypes. Change-Id: Id99b912e83052654a17d07dc92b4dcb958cb7600 Fixes: #4264
Diffstat (limited to 'lib/sqlalchemy/dialects/oracle/base.py')
-rw-r--r--lib/sqlalchemy/dialects/oracle/base.py44
1 files changed, 18 insertions, 26 deletions
diff --git a/lib/sqlalchemy/dialects/oracle/base.py b/lib/sqlalchemy/dialects/oracle/base.py
index e55a9cbc6..39acbf28d 100644
--- a/lib/sqlalchemy/dialects/oracle/base.py
+++ b/lib/sqlalchemy/dialects/oracle/base.py
@@ -411,38 +411,17 @@ class NUMBER(sqltypes.Numeric, sqltypes.Integer):
return sqltypes.Integer
-class DOUBLE_PRECISION(sqltypes.Numeric):
+class DOUBLE_PRECISION(sqltypes.Float):
__visit_name__ = 'DOUBLE_PRECISION'
- def __init__(self, precision=None, scale=None, asdecimal=None):
- if asdecimal is None:
- asdecimal = False
-
- super(DOUBLE_PRECISION, self).__init__(
- precision=precision, scale=scale, asdecimal=asdecimal)
-
-class BINARY_DOUBLE(sqltypes.Numeric):
+class BINARY_DOUBLE(sqltypes.Float):
__visit_name__ = 'BINARY_DOUBLE'
- def __init__(self, precision=None, scale=None, asdecimal=None):
- if asdecimal is None:
- asdecimal = False
-
- super(BINARY_DOUBLE, self).__init__(
- precision=precision, scale=scale, asdecimal=asdecimal)
-
-class BINARY_FLOAT(sqltypes.Numeric):
+class BINARY_FLOAT(sqltypes.Float):
__visit_name__ = 'BINARY_FLOAT'
- def __init__(self, precision=None, scale=None, asdecimal=None):
- if asdecimal is None:
- asdecimal = False
-
- super(BINARY_FLOAT, self).__init__(
- precision=precision, scale=scale, asdecimal=asdecimal)
-
class BFILE(sqltypes.LargeBinary):
__visit_name__ = 'BFILE'
@@ -536,6 +515,8 @@ ischema_names = {
'FLOAT': FLOAT,
'DOUBLE PRECISION': DOUBLE_PRECISION,
'LONG': LONG,
+ 'BINARY_DOUBLE': BINARY_DOUBLE,
+ 'BINARY_FLOAT': BINARY_FLOAT
}
@@ -585,17 +566,25 @@ class OracleTypeCompiler(compiler.GenericTypeCompiler):
def visit_BINARY_FLOAT(self, type_, **kw):
return self._generate_numeric(type_, "BINARY_FLOAT", **kw)
+ def visit_FLOAT(self, type_, **kw):
+ # don't support conversion between decimal/binary
+ # precision yet
+ kw['no_precision'] = True
+ return self._generate_numeric(type_, "FLOAT", **kw)
+
def visit_NUMBER(self, type_, **kw):
return self._generate_numeric(type_, "NUMBER", **kw)
- def _generate_numeric(self, type_, name, precision=None, scale=None, **kw):
+ def _generate_numeric(
+ self, type_, name, precision=None,
+ scale=None, no_precision=False, **kw):
if precision is None:
precision = type_.precision
if scale is None:
scale = getattr(type_, 'scale', None)
- if precision is None:
+ if no_precision or precision is None:
return name
elif scale is None:
n = "%(name)s(%(precision)s)"
@@ -1418,6 +1407,9 @@ class OracleDialect(default.DefaultDialect):
coltype = INTEGER()
else:
coltype = NUMBER(precision, scale)
+ elif coltype == 'FLOAT':
+ # TODO: support "precision" here as "binary_precision"
+ coltype = FLOAT()
elif coltype in ('VARCHAR2', 'NVARCHAR2', 'CHAR'):
coltype = self.ischema_names.get(coltype)(length)
elif 'WITH TIME ZONE' in coltype: