From 9c685dda38fddbe9ac1ab77693c48b340073a285 Mon Sep 17 00:00:00 2001 From: kkaruna Date: Tue, 30 Apr 2019 13:30:09 +0530 Subject: [PATCH] Problem Description: Table names which are created in Upper case in MYSQL is not searchable. Problem Cause: Under QualifiedName we are standardizing to lowercase for all database and tablenames. Its better to leave them as is as relational databases might be case sensitive. Problem Solution: Not standardizing the database, table and view Names --- .../java/com/netflix/metacat/common/QualifiedName.java | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/metacat-common/src/main/java/com/netflix/metacat/common/QualifiedName.java b/metacat-common/src/main/java/com/netflix/metacat/common/QualifiedName.java index 2e52beacb..58798334d 100644 --- a/metacat-common/src/main/java/com/netflix/metacat/common/QualifiedName.java +++ b/metacat-common/src/main/java/com/netflix/metacat/common/QualifiedName.java @@ -57,10 +57,12 @@ private QualifiedName( @Nullable final String viewName ) { this.catalogName = standardizeRequired("catalogName", catalogName); - this.databaseName = standardizeOptional(databaseName, true); - this.tableName = standardizeOptional(tableName, true); + // Database and table names are case sensitive in MySQL. Hence its best to leave them + // without standardize them + this.databaseName = standardizeOptional(databaseName, false); + this.tableName = standardizeOptional(tableName, false); this.partitionName = standardizeOptional(partitionName, false); - this.viewName = standardizeOptional(viewName, true); + this.viewName = standardizeOptional(viewName, false); if (this.databaseName.isEmpty() && (!this.tableName.isEmpty() || !this.partitionName.isEmpty())) { throw new IllegalStateException("databaseName is not present but tableName or partitionName are present");