<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
1、在B-tree索引中,表資料按照聚集索引的排序進行物理儲存,若聚集索引離散化比較嚴重,那麼可能會出現較為嚴重的碎片化問題;
2、隨著業務的DML操作,會伴隨著資料頁分裂的情況,這種情況下也會導致表空間碎片化問題;
3、大表通過delete清理無效歷史資料,delete產生碎片化空間;
表空間碎片化越嚴重越容易影響對該表的查詢效率,這是因為當表碎片化比較嚴重時,資料庫根據執行計劃掃描滿足需求的資料頁會掃描較多“無效頁面”,導致查詢操作需要更多的IO消耗。
1、在SQL Server中,可以通過DBCC SHOWCONTIG的方式檢視表空間碎片化的一些統計資訊,具體語法如下:
--檢視資料庫中所有索引的碎片資訊 use ${資料庫名} DBCC SHOWCONTIG WITH ALL_INDEXES --檢視指定表的所有索引的碎片資訊 DBCC SHOWCONTIG (${表名}) WITH ALL_INDEXES --檢視指定表、指定索引的碎片資訊 DBCC SHOWCONTIG (${表名},${索引名})
2、通過sys.dm_db_index_physical_stats()檢視索引碎片化
SELECT * FROM sys.dm_db_index_physical_stats(DB_ID(N'db1'), OBJECT_ID(N'db1.dbo.users'), NULL, NULL , 'LIMITED'); SELECT * FROM sys.dm_db_index_physical_stats(DB_ID(N'db1'), OBJECT_ID(N'db1.dbo.users'), NULL, NULL , 'DETAILED');
重點關注:
3、通過統計資訊檢視資料庫碎片化空間Top表資訊
SELECT db_name() as DbName, t.NAME AS TableName, s.Name AS SchemaName, p.rows AS RowCounts, SUM(a.total_pages) * 8 AS TotalSpaceKB, CAST(ROUND(((SUM(a.total_pages) * 8) / 1024.00), 2) AS NUMERIC(36, 2)) AS 總共佔用空間MB, SUM(a.used_pages) * 8 AS 總使用空間KB, CAST(ROUND(((SUM(a.used_pages) * 8) / 1024.00), 2) AS NUMERIC(36, 2)) AS 總使用空間MB, (SUM(a.total_pages) - SUM(a.used_pages)) * 8 AS 碎片化空間KB, CAST(ROUND(((SUM(a.total_pages) - SUM(a.used_pages)) * 8) / 1024.00, 2) AS NUMERIC(36, 2)) AS 碎片化空間MB FROM sys.tables t INNER JOIN sys.indexes i ON t.OBJECT_ID = i.object_id INNER JOIN sys.partitions p ON i.object_id = p.OBJECT_ID AND i.index_id = p.index_id INNER JOIN sys.allocation_units a ON p.partition_id = a.container_id LEFT OUTER JOIN sys.schemas s ON t.schema_id = s.schema_id WHERE t.is_ms_shipped = 0 AND i.OBJECT_ID > 0 GROUP BY t.Name, s.Name, p.Rows ORDER BY 總共佔用空間MB desc
由於表資料是根據聚集索引排序進行物理儲存,所以當表碎片化比較嚴重時,可以通過對聚集索引的重新組織來進行碎片化空間回收,重建索引的方式也有比較多方式,主要如下:
該方式其實就是將碎片化比較嚴重的表,先通過drop index刪除其聚集索引,然後通過create index或者alter table重建聚集索引。該方式的特點是:
使用DROP_EXISTING進行重建索引,也是對聚集索引的刪除重建,但是該方式在方法一的基礎上做了一些優化:
基本語法:
CREATE INDEX ${index_name} ON T(${index_col}) WITH (DROP_EXISTING = ON)
DBCC DBREINDEX也是通過對索引的刪除以及重建來實現碎片化回收。根據資料庫版本(企業版or非企業版)以及索引型別(非聚集or聚集),該操作是可以實現線上或者離線操作。
基本語法:
-- 重建指定索引 USE ${db_name}; GO DBCC DBREINDEX ('${schema_name}.${table_name}', ${index_name},80); GO -- 重建指定表全部索引 USE ${db_name}; GO DBCC DBREINDEX ('${schema_name}.${table_name}', ' ', 70); GO
該方式的實現邏輯與以上三種大有不同,DBCC INDEXDEFRAG並非完全重新組織整張表的b-tree結構:
DBCC INDEXDEFRAG按照索引鍵的邏輯順序,通過壓縮索引頁裡的行然後刪除那些由此產生的不必要的碎片化資料頁、刪除完全碎片化資料頁面的方式來進行碎片化空間的回收
該方式執行期間不阻塞業務讀寫操作
該方式下可回收的碎片化空間效果可能不如以上三種索引重建的方式
基本語法:
DBCC INDEXDEFRAG (${db_name}, '${schema_name}.${table_name}', ${index_name});
需要注意的是,在SQL Server資料庫,我們對錶空間資料進行碎片化處理、或者truncate清空無效歷史資料,這些釋放出來的空間只是空出來,當有新資料寫入時,優先使用這些空出來的資料頁,而不是再向OS申請新的資料空間擴充套件。所以這部分並不會直接釋放給OS,如果我們想要達到降低整個OS的磁碟空間使用率的話,還需要對資料庫的資料檔案進行收縮。
1、檢查資料檔案空間使用率
-- 檢查資料庫檔案空間使用率 SELECT a.name [檔名稱] ,cast(a.[size]*1.0/128 as decimal(12,1)) AS [檔案設定大小(MB)] , CAST( fileproperty(s.name,'SpaceUsed')/(8*16.0) AS DECIMAL(12,1)) AS [檔案所佔空間(MB)] , CAST( (fileproperty(s.name,'SpaceUsed')/(8*16.0))/(s.size/(8*16.0))*100.0 AS DECIMAL(12,1)) AS [所佔空間率%] , CASE WHEN A.growth =0 THEN '檔案大小固定,不會增長' ELSE '檔案將自動增長' end [增長模式] ,CASE WHEN A.growth > 0 AND is_percent_growth = 0 THEN '增量為固定大小' WHEN A.growth > 0 AND is_percent_growth = 1 THEN '增量將用整數百分比表示' ELSE '檔案大小固定,不會增長' END AS [增量模式] , CASE WHEN A.growth > 0 AND is_percent_growth = 0 THEN cast(cast(a.growth*1.0/128as decimal(12,0)) AS VARCHAR)+'MB' WHEN A.growth > 0 AND is_percent_growth = 1 THEN cast(cast(a.growth AS decimal(12,0)) AS VARCHAR)+'%' ELSE '檔案大小固定,不會增長' end AS [增長值(%或MB)] , a.physical_name AS [檔案所在目錄] ,a.type_desc AS [檔案型別] FROM sys.database_files a INNER JOIN sys.sysfiles AS s ON a.[file_id]=s.fileid LEFT JOIN sys.dm_db_file_space_usage b ON a.[file_id]=b.[file_id] ORDER BY a.[type]
2、收縮資料檔案
USE [${db_name}] GO DBCC SHRINKDATABASE(N'${db_name}' ) GO
到此這篇關於SQL Server表空間碎片化回收的實現的文章就介紹到這了,更多相關SQL Server表空間碎片化回收內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45