summaryrefslogtreecommitdiff
path: root/lib/sqlalchemy/engine/reflection.py
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2014-09-02 14:18:09 -0400
committerMike Bayer <mike_mp@zzzcomputing.com>2014-09-02 14:18:09 -0400
commitec840a6eea05ac031a55d262dc370bed942b2212 (patch)
tree9cd73f0a285fad400ca0e25cff6eccbf57d31af2 /lib/sqlalchemy/engine/reflection.py
parent9ee89dc88671a8c5d005c5baf3b2a7be58fee8ed (diff)
downloadsqlalchemy-ec840a6eea05ac031a55d262dc370bed942b2212.tar.gz
- An adjustment to table/index reflection such that if an index
reports a column that isn't found to be present in the table, a warning is emitted and the column is skipped. This can occur for some special system column situations as has been observed with Oracle. fixes #3180
Diffstat (limited to 'lib/sqlalchemy/engine/reflection.py')
-rw-r--r--lib/sqlalchemy/engine/reflection.py25
1 files changed, 17 insertions, 8 deletions
diff --git a/lib/sqlalchemy/engine/reflection.py b/lib/sqlalchemy/engine/reflection.py
index 012d1d35d..cf1f2d3dd 100644
--- a/lib/sqlalchemy/engine/reflection.py
+++ b/lib/sqlalchemy/engine/reflection.py
@@ -578,18 +578,27 @@ class Inspector(object):
name = index_d['name']
columns = index_d['column_names']
unique = index_d['unique']
- flavor = index_d.get('type', 'unknown type')
+ flavor = index_d.get('type', 'index')
if include_columns and \
not set(columns).issubset(include_columns):
util.warn(
- "Omitting %s KEY for (%s), key covers omitted columns." %
+ "Omitting %s key for (%s), key covers omitted columns." %
(flavor, ', '.join(columns)))
continue
# look for columns by orig name in cols_by_orig_name,
# but support columns that are in-Python only as fallback
- sa_schema.Index(name, *[
- cols_by_orig_name[c] if c in cols_by_orig_name
- else table.c[c]
- for c in columns
- ],
- **dict(unique=unique))
+ idx_cols = []
+ for c in columns:
+ try:
+ idx_col = cols_by_orig_name[c] \
+ if c in cols_by_orig_name else table.c[c]
+ except KeyError:
+ util.warn(
+ "%s key '%s' was not located in "
+ "columns for table '%s'" % (
+ flavor, c, table_name
+ ))
+ else:
+ idx_cols.append(idx_col)
+
+ sa_schema.Index(name, *idx_cols, **dict(unique=unique))