diff options
| author | Mike Bayer <mike_mp@zzzcomputing.com> | 2018-05-23 16:22:48 -0400 |
|---|---|---|
| committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2018-05-25 10:29:10 -0400 |
| commit | 6c27bf5048fc7335a1d1fdd49b651b1a164b8e32 (patch) | |
| tree | 3b447956383f636fa42d343fe5d816ac196ef5bc /lib/sqlalchemy/dialects/oracle/base.py | |
| parent | c7ae04d1c5c4aa6c6099584ae386d6ab9ef7b290 (diff) | |
| download | sqlalchemy-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.py | 44 |
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: |
