walterddr commented on code in PR #8893: URL: https://github.com/apache/pinot/pull/8893#discussion_r913887685
########## pinot-common/src/main/java/org/apache/pinot/common/utils/RegexpPatternConverterUtils.java: ########## @@ -33,7 +33,49 @@ private RegexpPatternConverterUtils() { * Converts a LIKE pattern into REGEXP_LIKE pattern. */ public static String likeToRegexpLike(String likePattern) { - return "^" + escapeMetaCharacters(likePattern).replace('_', '.').replace("%", ".*") + "$"; + int start = 0; + int end = likePattern.length(); + String prefix = "^"; + String suffix = "$"; + switch (likePattern.length()) { + case 0: + return "^$"; + case 1: + if (likePattern.charAt(0) == '%') { + return "^.*$"; + } + break; + default: + if (likePattern.charAt(0) == '%') { Review Comment: thanks for the explanation. it just seems ok to recursively prune out leading/trailing `%` e.g. instead of `start = 1;` we can do start equal to first non `%` char. -- This is an automated message from the Apache Git Service. To respond to the message, please log on to GitHub and use the URL above to go to the specific comment. To unsubscribe, e-mail: commits-unsubscr...@pinot.apache.org For queries about this service, please contact Infrastructure at: us...@infra.apache.org --------------------------------------------------------------------- To unsubscribe, e-mail: commits-unsubscr...@pinot.apache.org For additional commands, e-mail: commits-h...@pinot.apache.org