SQL Server數(shù)據(jù)表壓縮
概述
SQL Server的主要性能取決于磁盤I/O效率,SQL Server 。
2008提供了數(shù)據(jù)壓縮功能來提高磁盤I/O效率。
表壓縮意味著減小數(shù)據(jù)的磁盤占有量,所以壓縮可以用在堆表、聚集索引的表、非聚集索引的表、索引視圖、分區(qū)表上。
可壓縮的數(shù)據(jù)類型
smallint、int、Bigint、decimal、numeric、real、float、money、smallmoeny、bit、datetime、datetime2、datetimeoffset、char、nchar、binary、rowversion。
SQLServer中有兩種壓縮類型:數(shù)據(jù)與備份
行壓縮
壓縮會(huì)改變數(shù)據(jù)的物理存儲(chǔ)方式,但不需要對(duì)代碼做任何修改。
行壓縮流程:首先識(shí)別表中每一列的數(shù)據(jù)類型,然后轉(zhuǎn)換為可變長(zhǎng)度,最后將存儲(chǔ)空間的請(qǐng)求總量減少到實(shí)際需求量。
如:固定長(zhǎng)度的類型int、char、nchar等,在數(shù)據(jù)頁中以不定長(zhǎng)度的方式存儲(chǔ)(存儲(chǔ)真實(shí)數(shù)據(jù)長(zhǎng)度)。
1、SSMS行壓縮
表->右鍵->存儲(chǔ)->管理壓縮->對(duì)所有分區(qū)使用相同壓縮類型->右側(cè) 選擇row->立即執(zhí)行->完成。
ALTER TABLE [dbo].[AnnexFileList] REBUILD PARTITION = ALL WITH ( DATA_COMPRESSION = ROW );
在壓縮堆表或聚集索引時(shí)并不同時(shí)包含非聚集索引,因此需要另外單獨(dú)對(duì)非聚集索引進(jìn)行操作。
索引->右鍵->存儲(chǔ)->管理壓縮->對(duì)所有分區(qū)使用相同壓縮類型->右側(cè) 選擇row->立即執(zhí)行->完成。
ALTER INDEX [PK_ANNEXFILELIST] ON [dbo].[AnnexFileList] REBUILD PARTITION = ALL WITH ( DATA_COMPRESSION = ROW );
2、T-SQL行壓縮
--在現(xiàn)有表進(jìn)行壓縮 --聚集 alter table ceshi rebuild with(data_compression=row) --非聚集 alter index new_name on ceshi rebuild with(data_compression=row) --在創(chuàng)建表時(shí)進(jìn)行壓縮 create table yasuo ( id int primary key, name varchar(50), mail varchar(50) ) with (data_compression=row)
創(chuàng)建時(shí)指定行壓縮方式,這時(shí)并未發(fā)生改變。只要數(shù)據(jù)插入表中,該行即被壓縮。
頁壓縮
頁壓縮通過執(zhí)行額外的一些步驟增強(qiáng)了行壓縮的功能。
頁壓縮步驟:行壓縮、前綴壓縮、字典壓縮。
首先對(duì)于每一列將確定一個(gè)值,此值可以減少每一列中值的存儲(chǔ)空間。一旦確定該值后,每一列的前綴值的行將被存儲(chǔ)在頁頭中。所有的信息稱為壓縮信息,存儲(chǔ)在頁頭之下。標(biāo)識(shí)的值(前綴值)位于沒列中,將由指向壓縮信息部分中對(duì)應(yīng)值的引用進(jìn)行替換。
下一步字典壓縮,搜索整個(gè)頁面而非單個(gè)列,重復(fù)值被移動(dòng)到頁頭的壓縮信息部分,取而代之的是指向該值的引用。
在SSMS中頁壓縮步驟與行壓縮步驟一致,只是選擇壓縮方式為Page。T-SQL中將row改成page即可。
需要注意
1、如果保留在內(nèi)存中的數(shù)據(jù)是壓縮的,一旦被選中,則必須先進(jìn)行解壓縮。
2、在插入新行時(shí),數(shù)據(jù)也是行或頁壓縮的。
3、當(dāng)更新或刪除時(shí),行壓縮對(duì)象保留當(dāng)前的壓縮級(jí)別。但是頁壓縮可能需要重新計(jì)算,取決于發(fā)生變化的數(shù)據(jù)量。
用哪種壓縮
- 需要頻繁更新的對(duì)象應(yīng)該使用行壓縮。
- 只是執(zhí)行讀取操作的應(yīng)該使用頁壓縮。
到此這篇關(guān)于SQL Server數(shù)據(jù)表壓縮的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
MSSQL??附加數(shù)據(jù)庫提示“錯(cuò)誤?823”數(shù)據(jù)恢復(fù)實(shí)操
這篇文章主要介紹了MSSQL?2000?附加數(shù)據(jù)庫提示“錯(cuò)誤?823”數(shù)據(jù)恢復(fù)實(shí)操,報(bào)錯(cuò)823一般數(shù)據(jù)庫的物理頁面出現(xiàn)了損壞或者校驗(yàn)值損壞導(dǎo)致數(shù)據(jù)庫頁面無法被識(shí)別還有異常斷電導(dǎo)致的文件系統(tǒng)損壞,數(shù)據(jù)庫頁面丟失,下面針對(duì)錯(cuò)誤?823對(duì)數(shù)據(jù)進(jìn)行恢復(fù),需要的朋友可以參考一下2022-03-03SQL(MSSQLSERVER)服務(wù)啟動(dòng)錯(cuò)誤代碼3414的解決方法
這篇文章主要介紹了SQL(MSSQLSERVER)服務(wù)啟動(dòng)錯(cuò)誤代碼3414的解決方法,需要的朋友可以參考下2016-03-03SQL Server創(chuàng)建數(shù)據(jù)庫圖文教程
這篇文章主要介紹了SQL Server創(chuàng)建數(shù)據(jù)庫圖文教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02SQL Server 2005降級(jí)到2000的正確操作步驟分享
這篇文章主要和大家一起分享的是SQL Server 2005導(dǎo)入到SQL Server 2000的正確操作步驟,下面就是文章的主要內(nèi)容描述2014-04-04sqlserver 臨時(shí)表 Vs 表變量 詳細(xì)介紹
說臨時(shí)表和表變量,這是一個(gè)古老的話題,我們?cè)诰W(wǎng)上也找到很多的資料闡述兩者的特征,優(yōu)點(diǎn)與缺點(diǎn)2011-11-11SQL中WHERE變量IS NULL條件導(dǎo)致全表掃描問題的解決方法
今天在評(píng)審接手的項(xiàng)目中的存儲(chǔ)過程時(shí),發(fā)現(xiàn)存在大量的在條件里判斷變量是否NULL的寫法2013-09-09