[ 
https://issues.apache.org/jira/browse/HIVE-17264?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Jesse Santangelo updated HIVE-17264:
------------------------------------
    Affects Version/s: 2.3.0

> BaseSemanticAnalyzer.escapeSQLString escapes \0 unsafely
> --------------------------------------------------------
>
>                 Key: HIVE-17264
>                 URL: https://issues.apache.org/jira/browse/HIVE-17264
>             Project: Hive
>          Issue Type: Bug
>          Components: Query Planning
>    Affects Versions: 2.3.0
>            Reporter: Jesse Santangelo
>            Priority: Minor
>
> Currently escapeSQLString() converts the null character to \0. If there are 
> numerical values after the null character, calling unescapeSQLString() can 
> treat the resulting value as an octal literal.
> Example:
> "FOOBAR_EVENT\u00002017"
> unescapeSQLString converts \u0000 to the null character. Calling 
> escapeSQLString() on that resulting string currently gives
> "FOOBAR_EVENT\02017"
> A third call of unescapeSQLString() will then see \020 and convert it to 0x10.
> This is an issue for the Hbase connector where key values are processed twice 
> (I'm unfamiliar with the hive codebase so I don't know why) and so the 
> connector gets the wrong key value if it's formatted like the example.
> In my version I've changed escapeSQLString to replace the null character with 
> '\u0000' instead of '\0' and that seems to have fixed the issue, but I don't 
> know if that might break anything else.



--
This message was sent by Atlassian JIRA
(v6.4.14#64029)

Reply via email to