瀚高企业版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。

相关推荐
油炸自行车15 分钟前
【bug】Qt 6 Q_NAMESPACE 跨 DLL 链接错误:LNK2019 无法解析 staticMetaObject
数据库·c++·qt·bug·link2019·q_namespace_exp·namespaceexport
Arvin.Angela27 分钟前
MySQL安装及运行环境配置
数据库·mysql·adb
Dovis(誓平步青云)30 分钟前
《QT学习第五篇:QSS美化界面与API绘图》
开发语言·数据库·qt·学习·时序数据库·开源智能体
焦虑的说说37 分钟前
mysql深分页性能瓶颈根源分析
数据库·mysql
想你依然心痛38 分钟前
数据库技术在电力业务中的核心应用场景
java·开发语言·数据库
weixin_5231853243 分钟前
达梦数据库事务机制踩坑:默认不自动提交事务
数据库·oracle
小陈phd1 小时前
Qdrant 向量数据库从入门到实战:构建高效语义检索系统
数据库
xingyuzhisuan1 小时前
Redis 多级缓存落地聚合 API:重复请求降本 70% 实战数据
数据库·redis·缓存·ai
专注于大数据技术栈1 小时前
什么是Trino?大数据统一联邦查询引擎详解
大数据·数据库
数智化精益手记局1 小时前
拆解工程项目管理系统的核心功能:工程项目管理系统如何解决进度与成本难题
数据库·产品运营