文章目录
环境
系统平台:UOS(海光)
版本:9.0
症状
瀚高数据库版本:企业版 V9.1.1
症状: pg_restore还原备份文件时,提示下面错误
pg_restore: 来自 TOC 记录 259; 1259 16997 VIEW t_view highgo
pg_restore: 错误: could not execute query: 错误: 语法错误 在 "FROM" 或附近的
第2行 SELECT EXTRACT(second FROM (t.endtime - t.starttime)) AS du...
^
命令是: CREATE VIEW public.t_view AS
SELECT EXTRACT(second FROM (t.endtime - t.starttime)) AS duratime
FROM t;
问题原因
瀚高企业版V9.1.1初始化的时候,指定了-m oracle(双端口模式),使用5866端口创建表、添加数据,没有使用1521(oracle兼容)端口。
pg_dump备份的时候,也默认使用的5866端口,但是在备份文件的最开始添加了一些set语句,设定了oracle的兼容,如下所示:
sql
set ivorysql.compatible_mode to oracle; ##设定了oracle兼容
set session authorization system;
set ivorysql.dumppgtype to oracle;
set ivorysql.grant_usertype to oracle;
oracle兼容影响了pg模式下extract函数的语法,导致报错。
解决方案
在确定只使用pg模式,不使用oracle兼容的情况下,有以下两种方案:
1、pg_dump命令中添加 "-m pg" 选项,备份采用pg模式备份,则可解决问题。
2、如果数据量不大,用户允许重新初始化且可停机的前提下,可以重新初始化一下data,初始化时指定 -m pg,然后把原数据进行备份还原到新data下,以纯pg模式运行,这样pg_dump的时候可以不加-m pg。