You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@pinot.apache.org by GitBox <gi...@apache.org> on 2022/07/05 14:48:47 UTC

[GitHub] [pinot] walterddr commented on a diff in pull request #8893: Optimize like to regexp conversion to do not include unnecessary ^.* and .*$

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-unsubscribe@pinot.apache.org

For queries about this service, please contact Infrastructure at:
users@infra.apache.org


---------------------------------------------------------------------
To unsubscribe, e-mail: commits-unsubscribe@pinot.apache.org
For additional commands, e-mail: commits-help@pinot.apache.org