问题记录:Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错的问题

当使用Navicat连接PostgreSQL15时,由于pg_database表中缺少datlastsysoid字段导致报错。文章提供了三种解决方案:升级Navicat到最新版本,降级PostgreSQL,或者手动修改Navicat的libcc.dll文件,用dattablespace替换datlastsysoid。按照提供的步骤操作后,Navicat可以正常连接不同版本的PostgreSQL数据库。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错的问题

column “datlastsysoid“ does not exist 
Line1:SELECT DISTINCT datalastsysoid FROM pg_database

Postgres 15 从pg_database表中删除了 datlastsysoid 字段引发此错误。

决绝方案

  • 解决方法1:升级navicat

  • 解决方法2:降级pgsql

  • 解决方法3:修改dll

打开 Navicat 安装目录,找到libcc.dll文件

将其复制并粘贴为“libcc.dll.bak”或任何其他名称

件的备份(将其复制并粘贴为“libcc-backup.dll”或任何其他名称)

在任何十六进制编辑器中打开此文件,如果需要,您可以使用在线工具,例如 https://hexed.it/。

在文件中搜索“SELECT DISTINCT datlastsysoid”,并将其替换为“SELECT DISTINCT dattablespace”

将文件保存在原始位置。如果遇到任何安全问题,请将其另存为“.txt”文件,然后还原备份文件

重启navicat,可以发现,无论老和新版本的pgsql,都可以正常访问了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值