From 8df3c9ca8ae9196fd9e2c77b3a968dd06f15ae6d Mon Sep 17 00:00:00 2001 From: Sah Oss Date: Sat, 25 Feb 2023 10:26:45 +0530 Subject: [PATCH] Check primary_key exist during Ignite create table Adds a check for create table in IgniteClient. The check ensures that the column names mentioned in the table property 'primary_key' exists in the column defined in the create table statement. --- .../io/trino/plugin/ignite/IgniteClient.java | 25 +++++++++++++------ .../ignite/TestIgniteConnectorTest.java | 14 +++++++++++ 2 files changed, 32 insertions(+), 7 deletions(-) diff --git a/plugin/trino-ignite/src/main/java/io/trino/plugin/ignite/IgniteClient.java b/plugin/trino-ignite/src/main/java/io/trino/plugin/ignite/IgniteClient.java index 7ebd088b1c79..d61ea00a928b 100644 --- a/plugin/trino-ignite/src/main/java/io/trino/plugin/ignite/IgniteClient.java +++ b/plugin/trino-ignite/src/main/java/io/trino/plugin/ignite/IgniteClient.java @@ -115,6 +115,7 @@ import static io.trino.plugin.jdbc.StandardColumnMappings.varcharReadFunction; import static io.trino.plugin.jdbc.StandardColumnMappings.varcharWriteFunction; import static io.trino.spi.StandardErrorCode.INVALID_ARGUMENTS; +import static io.trino.spi.StandardErrorCode.INVALID_TABLE_PROPERTY; import static io.trino.spi.StandardErrorCode.NOT_SUPPORTED; import static io.trino.spi.type.BigintType.BIGINT; import static io.trino.spi.type.BooleanType.BOOLEAN; @@ -382,14 +383,25 @@ public JdbcOutputTableHandle beginCreateTable(ConnectorSession session, Connecto int expectedSize = tableMetadata.getColumns().size(); ImmutableList.Builder columns = ImmutableList.builderWithExpectedSize(expectedSize); - ImmutableList.Builder columnNames = ImmutableList.builderWithExpectedSize(expectedSize); + ImmutableList.Builder columnNamesBuilder = ImmutableList.builderWithExpectedSize(expectedSize); ImmutableList.Builder columnTypes = ImmutableList.builderWithExpectedSize(expectedSize); for (ColumnMetadata columnMetadata : tableMetadata.getColumns()) { columns.add(getColumnDefinitionSql(session, columnMetadata, columnMetadata.getName())); - columnNames.add(columnMetadata.getName()); + columnNamesBuilder.add(columnMetadata.getName()); columnTypes.add(columnMetadata.getType()); } - String sql = buildCreateSql(schemaTableName, columns.build(), tableMetadata.getProperties()); + + List columnNames = columnNamesBuilder.build(); + List primaryKeys = IgniteTableProperties.getPrimaryKey(tableMetadata.getProperties()); + + for (String primaryKey : primaryKeys) { + if (!columnNames.contains(primaryKey)) { + throw new TrinoException(INVALID_TABLE_PROPERTY, + format("Column '%s' specified in property '%s' doesn't exist in table", primaryKey, PRIMARY_KEY_PROPERTY)); + } + } + + String sql = buildCreateSql(schemaTableName, columns.build(), primaryKeys); try (Connection connection = connectionFactory.openConnection(session)) { execute(session, connection, sql); @@ -397,22 +409,21 @@ public JdbcOutputTableHandle beginCreateTable(ConnectorSession session, Connecto return new IgniteOutputTableHandle( schemaTableName.getSchemaName(), schemaTableName.getTableName(), - columnNames.build(), + columnNames, columnTypes.build(), Optional.empty(), - IgniteTableProperties.getPrimaryKey(tableMetadata.getProperties()).isEmpty() ? Optional.of(IGNITE_DUMMY_ID) : Optional.empty()); + primaryKeys.isEmpty() ? Optional.of(IGNITE_DUMMY_ID) : Optional.empty()); } catch (SQLException e) { throw new TrinoException(JDBC_ERROR, e); } } - private String buildCreateSql(SchemaTableName schemaTableName, List columns, Map tableProperties) + private String buildCreateSql(SchemaTableName schemaTableName, List columns, List primaryKeys) { ImmutableList.Builder columnDefinitions = ImmutableList.builder(); columnDefinitions.addAll(columns); - List primaryKeys = IgniteTableProperties.getPrimaryKey(tableProperties); checkArgument(primaryKeys.size() < columns.size(), "Ignite table must have at least one non PRIMARY KEY column."); if (primaryKeys.isEmpty()) { columnDefinitions.add(quoted(IGNITE_DUMMY_ID) + " VARCHAR NOT NULL"); diff --git a/plugin/trino-ignite/src/test/java/io/trino/plugin/ignite/TestIgniteConnectorTest.java b/plugin/trino-ignite/src/test/java/io/trino/plugin/ignite/TestIgniteConnectorTest.java index f3ade29f59fb..645f9608af38 100644 --- a/plugin/trino-ignite/src/test/java/io/trino/plugin/ignite/TestIgniteConnectorTest.java +++ b/plugin/trino-ignite/src/test/java/io/trino/plugin/ignite/TestIgniteConnectorTest.java @@ -189,6 +189,20 @@ public void testCreateTableWithCommaPropertyColumn() } } + @Test + public void testCreateTableWithNonExistingPrimaryKey() + { + String tableName = "test_invalid_primary_key" + randomNameSuffix(); + assertQueryFails("CREATE TABLE " + tableName + "(a bigint) WITH (primary_key = ARRAY['not_existing_column'])", + "Column 'not_existing_column' specified in property 'primary_key' doesn't exist in table"); + + assertQueryFails("CREATE TABLE " + tableName + "(a bigint) WITH (primary_key = ARRAY['dummy_id'])", + "Column 'dummy_id' specified in property 'primary_key' doesn't exist in table"); + + assertQueryFails("CREATE TABLE " + tableName + "(a bigint) WITH (primary_key = ARRAY['A'])", + "Column 'A' specified in property 'primary_key' doesn't exist in table"); + } + @Test public void testCreateTableWithAllProperties() {