时间:2020-04-19来源:电脑系统城作者:电脑系统城
问题场景:
在大批量删除数据库表部分数据、archive数据的时候,如果数据库表的非聚集索引比较多比较大,会严重影响删除性能,这时候就需要采取适当措施,避免删除数据过程中不断去维护非聚集索引,可以先临时删除/禁用一些非聚集索引,再进行数据删除操作,提高删除性能,删除完数据后,再重新创建加回/启用这部分非聚集索引。
解决方案1:
先备份非聚集索引,然后删除非聚集索引,最后重新创建非聚集索引。删除和创建索引脚本如下:
--临时删除非聚集索引 drop index [NonClusteredIndex-502219048] on [dbo].[table1] --============== --删除部分表数据 --============== --重新创建加回非聚集索引 create nonclustered index [NonClusteredIndex-502219048] on [dbo].[table1] ( [num] asc )
解决方案2(推荐):
先禁用非聚集索引,最后重新启用非聚集索引。禁用和启用索引脚本如下:
--临时禁用非聚集索引 alter index [NonClusteredIndex-502219048] on [dbo].[table1] disable --============== --删除部分表数据 --============== --重新启用非聚集索引 alter index [NonClusteredIndex-502219048] on [dbo].[table1] rebuild
2023-03-15
SQLserver存储过程写法与设置定时执行存储过程方法详解2023-03-11
sql语句将数据库一条数据通过分隔符切割成多列方法实例2023-03-06
MySQL中的常用树形结构设计总结最详细的 SQLSERVER ALWAYSON配置教程 一、准备工作: 二、搭建故障转移群集 三、搭建数据库AlwaysOn 四、过程中可能遇到的问题...
2023-03-06
2.1破解的时候,先要断网,然后再操作,按如图打开界面,点击Manage License 2.2点击Activate 2.3打开SQL.Prompt.Keygen.exe,将生成的注册码拷贝到输入框内,然后点击Activate 2.4 继续点击Activate manually 2.5 按如下步骤操...
2023-03-06