From 302af9cda4d4840040938a0d4a0012d6682e06b0 Mon Sep 17 00:00:00 2001 From: j Date: Tue, 12 Mar 2019 17:48:03 +0000 Subject: [PATCH] fix findindex in postgresql 10 --- pandora/item/management/commands/sqlfindindex.py | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/pandora/item/management/commands/sqlfindindex.py b/pandora/item/management/commands/sqlfindindex.py index bba3a247..c651e18f 100644 --- a/pandora/item/management/commands/sqlfindindex.py +++ b/pandora/item/management/commands/sqlfindindex.py @@ -45,12 +45,16 @@ class Command(BaseCommand): indexes = connection.introspection.get_indexes(cursor, table) drop = [] if column in indexes: - sql = "SELECT indexname, indexdef FROM pg_catalog.pg_indexes " + \ - "WHERE indexdef LIKE '%ON {table}%' AND indexdef LIKE '%{column}%'".format(table=table, column=column) - cursor.execute(sql) - for r in cursor: - if 'USING gin' not in r[1]: - drop.append(r[0]) + for sql in ( + "SELECT indexname, indexdef FROM pg_catalog.pg_indexes " + \ + "WHERE indexdef LIKE '%ON {table}%' AND indexdef LIKE '%{column}%'".format(table=table, column=column), + "SELECT indexname, indexdef FROM pg_catalog.pg_indexes " + \ + "WHERE indexdef LIKE '%ON public.{table}%' AND indexdef LIKE '%{column}%'".format(table=table, column=column), + ): + cursor.execute(sql) + for r in cursor: + if 'USING gin' not in r[1]: + drop.append(r[0]) if drop: for idx in drop: sql = 'DROP INDEX ' + idx