weixin_41083434 2023-04-08 01:01 采纳率: 25%
浏览 21
已结题

pgsql数据库线上问题

1、线上发版,执行pg_restore
2、执行成功之后,发现有的表成功了,有的表失败了,
失败的表有个特征:
字段存在,但是值为null,能够select count(*)总条数出来,值全部没了。
为什么会这样呢?

  • 写回答

1条回答 默认 最新

  •  ⁠⁡⁠ 2023-04-09 09:52
    关注

    在执行pg_restore恢复备份数据时,如果出现了字段存在但值为null的情况,可能有以下原因导致:

    恢复备份文件时没有指定正确的-c参数,该参数用于清除所有已有的数据和表结构,然后再从备份文件中恢复数据。如果不使用该参数,可能会出现一些数据表结构和数据的不一致情况。

    恢复备份文件时使用了-a参数或没有指定-C参数,该参数用于在恢复数据之前创建一个新的数据库,如果没有指定该参数,恢复的数据可能会与目标数据库中的数据不一致,导致一些表结构和数据的错误。

    数据库中某些表定义了外键约束,如果在备份数据时不包括所有相关的表,或者在恢复数据时没有正确的处理外键约束,就可能会出现字段存在但值为null的情况。

    为了避免出现这种情况,可以在恢复备份数据时,正确指定参数,清除已有的数据和表结构,然后再恢复数据。同时,需要确保所有相关的表都被备份,并正确处理外键约束。

    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 6月28日
  • 创建了问题 4月8日