diff --git a/django/contrib/gis/db/backends/oracle/introspection.py b/django/contrib/gis/db/backends/oracle/introspection.py index 886441a9d0..446dc78216 100644 --- a/django/contrib/gis/db/backends/oracle/introspection.py +++ b/django/contrib/gis/db/backends/oracle/introspection.py @@ -36,8 +36,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 67fb1ebd11..55b95b7f3c 100644 --- a/django/db/backends/oracle/base.py +++ b/django/db/backends/oracle/base.py @@ -530,7 +530,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 dd56252ef3..16dfc46d2c 100644 --- a/django/db/backends/oracle/introspection.py +++ b/django/db/backends/oracle/introspection.py @@ -78,7 +78,13 @@ class DatabaseIntrospection(BaseDatabaseIntrospection): name = force_text(desc[0]) # cx_Oracle always returns a 'str' 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 3ba4eb2e35..f20fb4bdd9 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 ~~~~~