开发者社区 > PolarDB开源 > PolarDB 分布式版 > 正文

为什么把上表drop后,PolarDB归档的表不能查询了?

d73d360e4963374dfae09a2ea363d368.png
mysql 的auto_dispatch_server_log_history_1 为什么把上表drop后,PolarDB归档的表不能查询了?

展开
收起
小小爱吃香菜 2024-01-03 01:10:50 70 0
2 条回答
写回答
取消 提交回答
  • 面对过去,不要迷离;面对未来,不必彷徨;活在今天,你只要把自己完全展示给别人看。

    PolarDB归档表是一种特殊的存储结构,用于长期保存历史数据。当一个表被drop后,其归档表也会受到影响。

    具体来说,当你删除一个表时,PolarDB会将该表的数据从主库中移除,并将其移动到归档库中。然后,归档库中的表会被标记为“已删除”,并且无法再进行查询。这是因为归档库主要用于长期存储和备份数据,而不是用于实时查询。

    如果你需要恢复已删除的表并重新进行查询,可以通过以下步骤操作:

    1. 首先,你需要在PolarDB中创建一个与已删除表结构相同的新表。可以使用CREATE TABLE语句来定义表的结构,包括列名、数据类型等。

    2. 然后,你可以使用INSERT INTO语句将归档库中的数据导入到新表中。这可以通过使用SELECT语句来实现,将归档库中的数据读取出来,并插入到新表中。

    3. 最后,你可以对新表进行查询操作,以获取所需的数据。

    需要注意的是,这个过程可能需要一定的时间和资源来完成,具体取决于归档库中的数据量和系统的性能。另外,如果归档库中的数据已经被永久删除或损坏,可能无法恢复。因此,在进行任何操作之前,请确保你已经备份了重要的数据。

    2024-01-03 14:23:46
    赞同 展开评论 打赏
  • 在PolarDB中,归档表是一种特殊的存储方式,用于长期保留历史数据。归档表的数据存储在独立的归档节点上,与主节点上的普通表分开存储。当用户删除或修改主节点上的表时,归档节点上的归档表不会自动同步这些更改。

    因此,如果您在删除主节点上的表后尝试查询归档表,可能会遇到以下问题:

    1. 归档表中的数据已经过时:由于归档表没有自动同步主节点上的更改,所以归档表中的数据可能已经不再准确或完整。

    2. 归档表的元数据丢失:当您删除主节点上的表时,与之相关的归档表的元数据(如列名、数据类型等)也可能被删除。这可能导致您无法正确查询归档表。

    为了解决这个问题,您可以采取以下措施:

    1. 重新创建归档表:如果您需要恢复已删除的表的归档数据,可以在主节点上重新创建相应的表,并确保启用归档功能。然后,等待一段时间以便归档节点上的数据同步到新创建的归档表中。

    2. 使用备份恢复数据:如果您没有启用归档功能或者无法重新创建归档表,可以尝试从备份中恢复数据。PolarDB提供了多种备份和恢复选项,如全量备份、增量备份和点时间恢复等。具体操作方法请参考官方文档。

    2024-01-03 08:53:16
    赞同 展开评论 打赏

PolarDB 分布式版 (PolarDB for Xscale,简称“PolarDB-X”) 采用 Shared-nothing 与存储计算分离架构,支持水平扩展、分布式事务、混合负载等能力,100%兼容MySQL。 2021年开源,开源历程及更多信息访问:OpenPolarDB.com/about

相关电子书

更多
PolarDB+AnalyticDB助力交通物流行业系统升级 立即下载
PolarDB NL2SQL: 帮助您写出准确、优化的SQL 立即下载
云栖大会:开源 PolarDB 架构演进、关键技术与社区建设 立即下载