暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

openGauss 删除索引

suger 2023-01-21
935

删除索引
和创建索引类似,删除索引也有concurrent和非concurrent两种方式,对应的加锁类型分别是ShareUpdateExclusiveLock和AccessExclusiveLock。

index_drop
concurrently
开启事务 tx1。

索引indisvalid设置为false,记WAL。index_set_state_flags(indexId, INDEX_DROP_CLEAR_VALID)

表的relcache失效,表和索引上加会话级别的ShareUpdateExclusiveLock,防止流程执行期间,其他流程修改元数据,例如 drop table。

提交事务 tx1。tx1提交后,新的事务查询不会使用该索引。

开启事务tx2。

等待所有的事务结束,有一些事务在tx1提交前已经开启,要确保没有事务查询使用该索引,需要等这些事务结束。

设置索引的indisready为false,indisvalid为true ? 有疑问,表的relcache失效。

提交事务tx2。

开启事务tx3。

等待所有的事务结束,有一些事务在tx2提交前已经开启,要确保没有事务更新该索引,需要等这些事务结束。

表加ShareUpdateExclusiveLock,索引上加AccessExclusiveLock,为删除索引文件做准备。

删除索引文件。

删除pg_index中索引数据,删除pg_class、pg_attribute中索引相关数据,刷新缓存。

释放会话级ShareUpdateExclusiveLock。

非concurrent删除索引流程上更简单一些,在表和索引上加AccessExclusiveLock,删除索引文件和相关元数据,刷新缓存。






原文链接:https://blog.csdn.net/enmotech/article/details/119362121

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论