瀚高企业版V9.1.1在pg_restore还原备份文件时提示extract函数语法问题

文章目录

环境

系统平台: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。

相关推荐
TDengine (老段)1 小时前
TDengine Tag 设计哲学与 Schema 变更机制
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
YOU OU2 小时前
Spring IoC&DI
java·数据库·spring
Muscleheng3 小时前
Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错
数据库·postgresql
罗超驿4 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试
jran-4 小时前
Redis 命令
数据库·redis·缓存
小江的记录本4 小时前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven
June`5 小时前
多线程redis下如何解决aof重写和rdb持久化的数据一致性问题
数据库·redis·缓存
二宝哥5 小时前
离线安装maven
java·数据库·maven
SZLSDH5 小时前
场景适配论 | 数字孪生IOC建设中渲染技术与智能体能力的协同逻辑
前端·数据库·ai·数字孪生·数据可视化·智能体