From f1225b918e5760a59664c8a8683f752159ba2f5c Mon Sep 17 00:00:00 2001 From: drabble Date: Mon, 3 Jun 2024 23:14:36 +0200 Subject: [PATCH] Fix OPTIONAL group cardinality --- .../storage/geoparquet/GeoParquetDataStore.java | 10 ++++------ .../storage/geoparquet/GeoParquetDataTable.java | 9 +++------ .../storage/geoparquet/GeoParquetTypeConversion.java | 9 ++++----- .../baremaps/workflow/tasks/ImportGeoParquet.java | 4 ++-- .../geoparquet/data/GeoParquetGroupFactory.java | 2 +- 5 files changed, 14 insertions(+), 20 deletions(-) diff --git a/baremaps-core/src/main/java/org/apache/baremaps/storage/geoparquet/GeoParquetDataStore.java b/baremaps-core/src/main/java/org/apache/baremaps/storage/geoparquet/GeoParquetDataStore.java index 46283391f..05874cf91 100644 --- a/baremaps-core/src/main/java/org/apache/baremaps/storage/geoparquet/GeoParquetDataStore.java +++ b/baremaps-core/src/main/java/org/apache/baremaps/storage/geoparquet/GeoParquetDataStore.java @@ -30,24 +30,22 @@ public class GeoParquetDataStore implements DataStore { private final URI uri; - private final String tableName; - public GeoParquetDataStore(URI uri, String tableName) { + public GeoParquetDataStore(URI uri) { this.uri = uri; - this.tableName = tableName; } @Override public List list() throws DataStoreException { - return List.of(tableName); + return List.of(uri.toString()); } @Override public DataTable get(String name) throws DataStoreException { - if (!tableName.equals(name)) { + if (!uri.toString().equals(name)) { throw new DataStoreException("Table not found"); } - return new GeoParquetDataTable(uri, tableName); + return new GeoParquetDataTable(uri); } @Override diff --git a/baremaps-core/src/main/java/org/apache/baremaps/storage/geoparquet/GeoParquetDataTable.java b/baremaps-core/src/main/java/org/apache/baremaps/storage/geoparquet/GeoParquetDataTable.java index dcfa43838..860a2e3db 100644 --- a/baremaps-core/src/main/java/org/apache/baremaps/storage/geoparquet/GeoParquetDataTable.java +++ b/baremaps-core/src/main/java/org/apache/baremaps/storage/geoparquet/GeoParquetDataTable.java @@ -32,15 +32,12 @@ public class GeoParquetDataTable implements DataTable { private final URI path; - private final String name; - private DataSchema schema; private GeoParquetReader reader; - public GeoParquetDataTable(URI path, String name) { + public GeoParquetDataTable(URI path) { this.path = path; - this.name = name; } private GeoParquetReader reader() { @@ -78,7 +75,7 @@ public Stream stream() { public Stream parallelStream() { try { return reader().read().map(group -> new DataRowImpl( - GeoParquetTypeConversion.asSchema(name, group.getSchema()), + GeoParquetTypeConversion.asSchema(path.toString(), group.getSchema()), GeoParquetTypeConversion.asRowValues(group))); } catch (IOException | URISyntaxException e) { throw new GeoParquetException("Fail to read() the reader", e); @@ -101,7 +98,7 @@ public DataSchema schema() { if (schema == null) { try { Schema schema = reader().getGeoParquetSchema(); - this.schema = GeoParquetTypeConversion.asSchema(name, schema); + this.schema = GeoParquetTypeConversion.asSchema(path.toString(), schema); return this.schema; } catch (URISyntaxException e) { throw new GeoParquetException("Failed to get the schema.", e); diff --git a/baremaps-core/src/main/java/org/apache/baremaps/storage/geoparquet/GeoParquetTypeConversion.java b/baremaps-core/src/main/java/org/apache/baremaps/storage/geoparquet/GeoParquetTypeConversion.java index 1d802673a..435effa5e 100644 --- a/baremaps-core/src/main/java/org/apache/baremaps/storage/geoparquet/GeoParquetTypeConversion.java +++ b/baremaps-core/src/main/java/org/apache/baremaps/storage/geoparquet/GeoParquetTypeConversion.java @@ -46,9 +46,9 @@ private static List asDataColumns(Schema field) { private static DataColumn asDataColumn(Field field) { Cardinality cardinality = switch (field.cardinality()) { - case REQUIRED -> Cardinality.OPTIONAL; + case REQUIRED -> Cardinality.REQUIRED; case OPTIONAL -> Cardinality.OPTIONAL; - case REPEATED -> Cardinality.OPTIONAL; + case REPEATED -> Cardinality.REPEATED; }; return switch (field.type()) { case BINARY -> new DataColumnFixed(field.name(), cardinality, Type.BINARY); @@ -70,11 +70,11 @@ public static List asRowValues(GeoParquetGroup group) { Schema schema = group.getSchema(); List fields = schema.fields(); for (int i = 0; i < fields.size(); i++) { - Field field = fields.get(i); if (group.getValues(i).isEmpty()) { values.add(null); continue; } + Field field = fields.get(i); switch (field.type()) { case BINARY -> values.add(group.getBinaryValue(i).getBytes()); case BOOLEAN -> values.add(group.getBooleanValue(i)); @@ -96,11 +96,10 @@ public static Map asNested(GeoParquetGroup group) { Schema schema = group.getSchema(); List fields = schema.fields(); for (int i = 0; i < fields.size(); i++) { - Field field = fields.get(i); if (group.getValues(i).isEmpty()) { - nested.put(field.name(), null); continue; } + Field field = fields.get(i); nested.put(field.name(), switch (field.type()) { case BINARY -> group.getBinaryValue(i).getBytes(); case BOOLEAN -> group.getBooleanValue(i); diff --git a/baremaps-core/src/main/java/org/apache/baremaps/workflow/tasks/ImportGeoParquet.java b/baremaps-core/src/main/java/org/apache/baremaps/workflow/tasks/ImportGeoParquet.java index d85f27dba..9caddead3 100644 --- a/baremaps-core/src/main/java/org/apache/baremaps/workflow/tasks/ImportGeoParquet.java +++ b/baremaps-core/src/main/java/org/apache/baremaps/workflow/tasks/ImportGeoParquet.java @@ -68,7 +68,7 @@ public ImportGeoParquet(URI uri, String tableName, Object database, Integer data */ @Override public void execute(WorkflowContext context) throws Exception { - var geoParquetDataStore = new GeoParquetDataStore(uri, tableName); + var geoParquetDataStore = new GeoParquetDataStore(uri); var dataSource = context.getDataSource(database); var postgresDataStore = new PostgresDataStore(dataSource); for (var name : geoParquetDataStore.list()) { @@ -80,7 +80,7 @@ public void execute(WorkflowContext context) throws Exception { new DataTableGeometryMapper(geoParquetTable, projectionTransformer); var transformedDataTable = new DataTableMapper(geoParquetDataStore.get(name), rowTransformer); - postgresDataStore.add(transformedDataTable); + postgresDataStore.add(tableName, transformedDataTable); } } diff --git a/baremaps-geoparquet/src/main/java/org/apache/baremaps/geoparquet/data/GeoParquetGroupFactory.java b/baremaps-geoparquet/src/main/java/org/apache/baremaps/geoparquet/data/GeoParquetGroupFactory.java index f925df50c..5abe77642 100644 --- a/baremaps-geoparquet/src/main/java/org/apache/baremaps/geoparquet/data/GeoParquetGroupFactory.java +++ b/baremaps-geoparquet/src/main/java/org/apache/baremaps/geoparquet/data/GeoParquetGroupFactory.java @@ -69,7 +69,7 @@ else if (!field.isPrimitive()) { GeoParquetGroup.Schema geoParquetSchema = createGeoParquetSchema(groupType, metadata); return (Field) new GeoParquetGroup.GroupField( groupType.getName(), - GeoParquetGroup.Cardinality.REQUIRED, + cardinality, geoParquetSchema); }