From 5ed1fc6c773dc6b513efb602c4a91de24ecdb2f6 Mon Sep 17 00:00:00 2001 From: suxinshuo <34018346+suxinshuo@users.noreply.github.com> Date: Thu, 18 Jul 2024 10:33:05 +0800 Subject: [PATCH] [Feature-3532][admin] Supports viewing schema of SQL tables with complex data types in catalog (#3640) Co-authored-by: suxinshuo --- .../dinky/utils/FlinkTableMetadataUtil.java | 20 ++++--------------- .../java/org/dinky/data/enums/ColumnType.java | 19 ++++++++++++++++++ 2 files changed, 23 insertions(+), 16 deletions(-) diff --git a/dinky-client/dinky-client-base/src/main/java/org/dinky/utils/FlinkTableMetadataUtil.java b/dinky-client/dinky-client-base/src/main/java/org/dinky/utils/FlinkTableMetadataUtil.java index 7fcc9c96b7..5260c5fdcf 100644 --- a/dinky-client/dinky-client-base/src/main/java/org/dinky/utils/FlinkTableMetadataUtil.java +++ b/dinky-client/dinky-client-base/src/main/java/org/dinky/utils/FlinkTableMetadataUtil.java @@ -110,22 +110,10 @@ public static List getColumnList( column.setScale(((DecimalType) logicalType).getScale()); } - for (ColumnType columnType : ColumnType.values()) { - if (columnType - .getJavaType() - .equals(flinkColumn - .getDataType() - .getConversionClass() - .getName())) { - column.setJavaType(columnType); - break; - } - } - // FlinkColumn flinkColumn = FlinkColumn.build(i, - // column.getName(), column.getDataType().getConversionClass().getName(), - // isPrimaryKey.get(), column.getDataType().getLogicalType().isNullable(), - // column.explainExtras().orElse(""), "", column.getComment().orElse("")); - + String dataTypeName = + flinkColumn.getDataType().getConversionClass().getName(); + ColumnType columnType = ColumnType.getByJavaType(dataTypeName); + column.setJavaType(columnType); columns.add(column); } }); diff --git a/dinky-common/src/main/java/org/dinky/data/enums/ColumnType.java b/dinky-common/src/main/java/org/dinky/data/enums/ColumnType.java index 8f55bd476b..1d396b1e26 100644 --- a/dinky-common/src/main/java/org/dinky/data/enums/ColumnType.java +++ b/dinky-common/src/main/java/org/dinky/data/enums/ColumnType.java @@ -19,7 +19,11 @@ package org.dinky.data.enums; +import java.util.Arrays; +import java.util.Map; + import com.fasterxml.jackson.annotation.JsonValue; +import com.google.common.collect.Maps; /** * ColumnType @@ -61,6 +65,17 @@ public enum ColumnType { private final String javaType; private final String flinkType; + /** + * JavaType -> ColumnType + */ + private static final Map JAVA_COL_TYPE_MAP = Maps.newHashMap(); + + static { + Arrays.stream(ColumnType.values()).forEach(columnType -> { + JAVA_COL_TYPE_MAP.put(columnType.getJavaType(), columnType); + }); + } + ColumnType(String javaType, String flinkType) { this.javaType = javaType; this.flinkType = flinkType; @@ -74,4 +89,8 @@ public String getJavaType() { public String getFlinkType() { return flinkType; } + + public static ColumnType getByJavaType(String javaType) { + return JAVA_COL_TYPE_MAP.getOrDefault(javaType, STRING); + } }