zl程序教程

您现在的位置是:首页 >  其它

当前栏目

PostgreSQLERROR:invalidescapestring解决办法

解决办法
2023-06-13 09:15:37 时间

今天有同事在配置PostgreSQL为Hive元数据库后,运行HiveSQL时遇到以下报错信息:

复制代码代码如下:


Causedby:MetaException(message:Gotexception:org.apache.hadoop.hive.metastore.api.MetaExceptionjavax.jdo.JDODataStoreException:ErrorexecutingJDOQLquery“SELECT“THIS”.”NAME”ASNUCORDER0FROM“DBS”“THIS”WHERE(LOWER(“THIS”.”NAME”)LIKE?ESCAPE‘\\")ORDERBYNUCORDER0”:ERROR:invalidescapestring
Hint:Escapestringmustbeemptyoronecharacter..

错误信息很清楚,ESCAPE‘\\"这里,引号内只能为一个字符,而不能是两个\。解决的办法很简单,将该JDBC用户的连接session属性standard_conforming_strings设置为off即可。

复制代码代码如下:


ALTERROLExxINDATABASEyySETstandard_conforming_stringsTOoff;

错误原因说明

早期PG普通字符串中的"\"是作为转义字符对待的,所以"\\"最终会认为是"\"。但是这是不符合SQL标准的,所以在PG9.1及以后,普通字符串中的\不会被任务是转义字符,而E"xx\x"中的\才会被当作是转义字符。为了使以前的代码可以在新的PG版本中运行,便有了standard_conforming_strings这个选项,这个选项默认是on,表示按照SQL标准处理字符串,当设置为off时,按照PG的旧版本处理字符串。