From 8ca9054c8818f8eab915f6abf0cde47754996ef1 Mon Sep 17 00:00:00 2001 From: floptical Date: Fri, 12 Apr 2024 14:43:00 -0400 Subject: [PATCH] additional check for non-registered postgis tables (courtesy of jrmidkiff) --- geopetl/postgis.py | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/geopetl/postgis.py b/geopetl/postgis.py index d87a95c..64ae3f1 100644 --- a/geopetl/postgis.py +++ b/geopetl/postgis.py @@ -602,11 +602,10 @@ def geom_field(self): stmt = '''select f_geometry_column as column_name from geometry_columns where f_table_name = '{table_name}' and f_table_schema = '{table_schema}' '''.format(table_name=self.name, table_schema=self.schema) target_table_shape_fields = self.db.fetch(stmt) - - elif self.db.is_postgis_enabled: - # this query should work for both postgis mview and table + # Could be an odd situation where we have a non-registered table, but the table still has postgis geometry. + elif self.db.is_postgis_enabled and not target_table_shape_fields: stmt = '''select f_geometry_column as column_name from geometry_columns - where f_table_name = '{table_name}' and f_table_schema = '{table_schema}' '''.format(table_name=self.name, table_schema=self.schema) + where f_table_name = '{table_name}' and f_table_schema = '{table_schema}' '''.format(table_name=self.name, table_schema=self.schema) target_table_shape_fields = self.db.fetch(stmt) # if we find shape fields in target tables/view/materialized vies