diff --git a/django/contrib/gis/db/backends/oracle/introspection.py b/django/contrib/gis/db/backends/oracle/introspection.py index 764ce7d2431..555853731d3 100644 --- a/django/contrib/gis/db/backends/oracle/introspection.py +++ b/django/contrib/gis/db/backends/oracle/introspection.py @@ -40,8 +40,8 @@ class OracleIntrospection(DatabaseIntrospection): dim, srid = row if srid != 4326: field_params['srid'] = srid - # Length of object array ( SDO_DIM_ARRAY ) is number of dimensions. - dim = len(dim) + # Size of object array (SDO_DIM_ARRAY) is number of dimensions. + dim = dim.size() if dim != 2: field_params['dim'] = dim finally: diff --git a/django/db/backends/oracle/base.py b/django/db/backends/oracle/base.py index 8e23b95fed2..be604455cf5 100644 --- a/django/db/backends/oracle/base.py +++ b/django/db/backends/oracle/base.py @@ -550,7 +550,8 @@ def _rowfactory(row, cursor): casted = [] for value, desc in zip(row, cursor.description): if value is not None and desc[1] is Database.NUMBER: - precision, scale = desc[4:6] + precision = desc[4] or 0 + scale = desc[5] or 0 if scale == -127: if precision == 0: # NUMBER column: decimal-precision floating point diff --git a/django/db/backends/oracle/introspection.py b/django/db/backends/oracle/introspection.py index 2d04fdac56d..10bcdefc2d1 100644 --- a/django/db/backends/oracle/introspection.py +++ b/django/db/backends/oracle/introspection.py @@ -84,7 +84,13 @@ class DatabaseIntrospection(BaseDatabaseIntrospection): name = force_text(desc[0]) # cx_Oracle always returns a 'str' on both Python 2 and 3 internal_size, default = field_map[name] name = name % {} # cx_Oracle, for some reason, doubles percent signs. - description.append(FieldInfo(*(name.lower(),) + desc[1:3] + (internal_size,) + desc[4:] + (default,))) + description.append(FieldInfo(*( + (name.lower(),) + + desc[1:3] + + (internal_size, desc[4] or 0, desc[5] or 0) + + desc[6:] + + (default,) + ))) return description def table_name_converter(self, name): diff --git a/docs/releases/1.11.txt b/docs/releases/1.11.txt index 3ba4eb2e35d..f20fb4bdd9d 100644 --- a/docs/releases/1.11.txt +++ b/docs/releases/1.11.txt @@ -263,6 +263,8 @@ Database backends `. To avoid possible data loss, it's recommended to switch from MySQL's default level, repeatable read, to read committed. +* Added support for ``cx_Oracle`` 5.3. + Email ~~~~~