shouhengyi opened a new issue #7324:
URL: https://github.com/apache/pinot/issues/7324


   In 
[PreparedStatement.java](https://github.com/apache/pinot/blob/master/pinot-clients/pinot-java-client/src/main/java/org/apache/pinot/client/PreparedStatement.java),
 if `value` argument in the `setString` method contains dollar sign "$", it 
will cause `IndexOutOfBoundsException` when `fillStatementWithParameters` is 
invoked. For example, if `value` is `"$8.00"`, we will get exceptions like this.
   ```
   java.lang.IndexOutOfBoundsException: No group 8
       at java.util.regex.Matcher.start(Matcher.java:375)
       at java.util.regex.Matcher.appendReplacement(Matcher.java:880)
       at java.util.regex.Matcher.replaceFirst(Matcher.java:1004)
       at java.lang.String.replaceFirst(String.java:2178)
       at 
org.apache.pinot.client.PreparedStatement.fillStatementWithParameters(PreparedStatement.java:61)
       ...
   ```
   This is due to that the dollar sign $ is not properly escaped. To fix this 
issue, our proposal is to escape dollar sign in the `value`:
   ```
     public void setString(int parameterIndex, String value) {
       _parameters[parameterIndex] = "'" + value.replace("'", 
"''").replace("$", "//$") + "'";
     }
   ```


-- 
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

Reply via email to