
文章目录环境症状问题原因解决方案环境系统平台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端口创建表、添加数据没有使用1521oracle兼容端口。pg_dump备份的时候也默认使用的5866端口但是在备份文件的最开始添加了一些set语句设定了oracle的兼容如下所示setivorysql.compatible_modetooracle;##设定了oracle兼容setsessionauthorizationsystem;setivorysql.dumppgtypetooracle;setivorysql.grant_usertypetooracle;oracle兼容影响了pg模式下extract函数的语法导致报错。解决方案在确定只使用pg模式不使用oracle兼容的情况下有以下两种方案1、pg_dump命令中添加 “-m pg” 选项备份采用pg模式备份则可解决问题。2、如果数据量不大用户允许重新初始化且可停机的前提下可以重新初始化一下data初始化时指定 -m pg然后把原数据进行备份还原到新data下以纯pg模式运行这样pg_dump的时候可以不加-m pg。