加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

postgresql – 清除已删除列的postgres知识

发布时间:2020-12-13 16:01:06 所属栏目:百科 来源:网络整理
导读:我在postgres数据库中有一个表,它在一个测试环境中使用,我们需要一次添加和删除几列.问题是postgres最多有1600列,这个计数包括删除的列.我的桌子上永远不会有1600个“未掉落”的列,但随着时间的推移,它会累积到1600以上. 我尝试过使用VACUUM和VACUUM FULL,我
我在postgres数据库中有一个表,它在一个测试环境中使用,我们需要一次添加和删除几列.问题是postgres最多有1600列,这个计数包括删除的列.我的桌子上永远不会有1600个“未掉落”的列,但随着时间的推移,它会累积到1600以上.

我尝试过使用VACUUM和VACUUM FULL,我尝试将现有列重新编写为自己的类型(ALTER TABLE表ALTER COLUMN anycol TYPE anytype),以使postgres扫描所有列并清除已删除列中的内存,但这些都没有重置postgres的“列号”.

我知道这可以通过复制整个表来解决,但这有其自身的问题,并且是一个单独的问题.

你知道一种方法让postgres忘记它已经删除了列吗?

我知道postgres不是为这样的应用程序设计的,但我不打算理解为什么我们选择以这种方式实现它.如果你有一个替代工具可以使用,我有兴趣听听它,但我仍然想找到解决方案.

解决方法

除了通过重新创建表格之外,这是不可能的,正如您已经发现的那样.

否则,数据库系统必须以某种方式跟踪被删除列使用的存储何时被清除,然后重新编号属性.那将是非常昂贵和复杂的.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读