日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

SQL?Server數據表壓縮_MsSql

作者:springsnow ? 更新時間: 2022-07-15 編程語言

概述

SQL Server的主要性能取決于磁盤I/O效率,SQL Server 。
2008提供了數據壓縮功能來提高磁盤I/O效率。
表壓縮意味著減小數據的磁盤占有量,所以壓縮可以用在堆表、聚集索引的表、非聚集索引的表、索引視圖、分區表上。

可壓縮的數據類型

smallint、int、Bigint、decimal、numeric、real、float、money、smallmoeny、bit、datetime、datetime2、datetimeoffset、char、nchar、binary、rowversion。

SQLServer中有兩種壓縮類型:數據與備份

行壓縮

壓縮會改變數據的物理存儲方式,但不需要對代碼做任何修改。
行壓縮流程:首先識別表中每一列的數據類型,然后轉換為可變長度,最后將存儲空間的請求總量減少到實際需求量。
如:固定長度的類型int、char、nchar等,在數據頁中以不定長度的方式存儲(存儲真實數據長度)。

1、SSMS行壓縮

表->右鍵->存儲->管理壓縮->對所有分區使用相同壓縮類型->右側 選擇row->立即執行->完成。

image

ALTER TABLE [dbo].[AnnexFileList] REBUILD PARTITION = ALL
WITH ( DATA_COMPRESSION = ROW );

在壓縮堆表或聚集索引時并不同時包含非聚集索引,因此需要另外單獨對非聚集索引進行操作。

索引->右鍵->存儲->管理壓縮->對所有分區使用相同壓縮類型->右側 選擇row->立即執行->完成。

image

ALTER INDEX [PK_ANNEXFILELIST]
    ON [dbo].[AnnexFileList]   REBUILD PARTITION = ALL
    WITH ( DATA_COMPRESSION = ROW );

2、T-SQL行壓縮

--在現有表進行壓縮
--聚集
alter table ceshi rebuild with(data_compression=row)

--非聚集
alter index new_name on ceshi rebuild with(data_compression=row) 

--在創建表時進行壓縮
create table yasuo
(
    id int primary key,
    name varchar(50),
    mail varchar(50)
)
with (data_compression=row)

創建時指定行壓縮方式,這時并未發生改變。只要數據插入表中,該行即被壓縮。

頁壓縮

頁壓縮通過執行額外的一些步驟增強了行壓縮的功能。

頁壓縮步驟:行壓縮、前綴壓縮、字典壓縮。

首先對于每一列將確定一個值,此值可以減少每一列中值的存儲空間。一旦確定該值后,每一列的前綴值的行將被存儲在頁頭中。所有的信息稱為壓縮信息,存儲在頁頭之下。標識的值(前綴值)位于沒列中,將由指向壓縮信息部分中對應值的引用進行替換。
下一步字典壓縮,搜索整個頁面而非單個列,重復值被移動到頁頭的壓縮信息部分,取而代之的是指向該值的引用。

在SSMS中頁壓縮步驟與行壓縮步驟一致,只是選擇壓縮方式為Page。T-SQL中將row改成page即可。

需要注意

1、如果保留在內存中的數據是壓縮的,一旦被選中,則必須先進行解壓縮。

2、在插入新行時,數據也是行或頁壓縮的。

3、當更新或刪除時,行壓縮對象保留當前的壓縮級別。但是頁壓縮可能需要重新計算,取決于發生變化的數據量。

用哪種壓縮

  • 需要頻繁更新的對象應該使用行壓縮。
  • 只是執行讀取操作的應該使用頁壓縮。

原文鏈接:https://www.cnblogs.com/springsnow/p/9599408.html

欄目分類
最近更新