首页 > 数据库 >SQL Server(00):表压缩

SQL Server(00):表压缩

时间:2024-12-20 15:23:51浏览次数:5  
标签:00 压缩 存储 Server 索引 SQL row

SQL Server(00):表压缩

目录

 


概述

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、当更新或删除时,行压缩对象保留当前的压缩级别。但是页压缩可能需要重新计算,取决于发生变化的数据量。

用哪种压缩

  • 需要频繁更新的对象应该使用行压缩。
  • 只是执行读取操作的应该使用页压缩。

标签:00,压缩,存储,Server,索引,SQL,row
From: https://www.cnblogs.com/raincedar/p/18619341

相关文章

  • Java项目实战之基于 Spring Boot+MyBatisPlus+MySQL+JSP的毕业设计综合信息管理系统
    1.引言1.1项目背景毕业设计是高等教育中的重要环节,为了提高毕业设计管理的效率和质量,实现信息化管理,特开发本毕业设计综合信息管理系统。该系统涵盖了毕业设计过程中的各个环节,包括管理员信息管理、院系专业管理、学生信息管理、教师信息管理、论文题目审核、选题信息管理、历......
  • SQLAlchemy与Pandas版本差异中的URL字符问题:quote_plus来解决
    在数据科学和工程领域,SQLAlchemy和Pandas是两个极其常用的Python库。SQLAlchemy是一个强大的SQL工具包和对象关系映射(ORM)库,而Pandas则是数据处理和分析的必备工具。然而,在使用这两个库进行数据库操作时,特别是当它们的版本之间存在较大差异时,你可能会遇到一些字符处理的问题,尤其是......
  • 这个Mysql的秘密,老师不会告诉你-章节4:Mysql锁
    一、概述    锁的概念大家并不陌生,计算机科学中,锁是在执行多线程时用于强行限制资源访问的同步机制,即用于在并发控制中保证对互斥要求的满足。那么在Mysql中,数据库锁设计的初衷也是处理并发问题。二、锁分类        根据加锁的范围,MySQL里面的锁大致可以......
  • SQL注入
    对上一篇文章的进一步说明,补充了报错注入和sql注入getshell0x01:联合查询注入常用语句:/?id=1'and1'='2或/?id=1and1=2//判断是字符型注入还是数字型注入//下面以字符型为例/?id=1'unionselect1,2,3#//爆回显位/?id=1'unionselect1,2,database()#//爆数据库名/?i......
  • MySQL 开启配置binlog以及通过binlog恢复数据
    --------------------------------------------------------------------------------------#查看binlog的列表,确定需要恢复的时间点或日志文件mysqlbinlog--list-binlog-files #恢复指定时间范围的数据mysqlbinlog--start-datetime="2023-03-0100:00:00"--stop-datet......
  • GA/T1400视图库平台EasyCVR如何计算监控设备所需的带宽来选择PoE交换机?
    在构建一个高效、稳定的监控系统时,选择合适的PoE交换机以满足监控设备所需的带宽是至关重要的一步。带宽不足可能导致视频流卡顿、延迟甚至数据丢失,而带宽过剩则可能导致不必要的成本浪费。因此,精确计算监控设备所需的带宽对于确保监控系统的可靠性和经济性至关重要。以下是详细......
  • Windows Server 2019 Datacenter 激活码——亲测可用
    目前网络上流行的 WindowsServer2019KMS激活可以很方便且快速完成激活,而且不用担心安全问题。如果您是计算机运维人员,那么 WindowsServer2019想必肯定有接触不少,那么现在就来一起看看如何激活该系统吧。WindowsServer2019有三个版本,在安装的时候我们可以采用微软官......
  • Java项目实战之基于springboot+vue+mysql+jpa+redis的企业网站搭建设计文档设计与实现
    一、引言1.1项目背景随着互联网的飞速发展,企业网站已成为企业展示形象、推广产品和服务、与客户沟通的重要窗口。为了提升企业的竞争力,需要构建一个功能完善、用户体验良好的企业网站。1.2项目目标本项目旨在打造一个专业、高效、易用的企业网站,满足企业在品牌展示、产品推......
  • scrapy中pipelines文件封装用sqlalchemy写入mysql数据库
    #前提必须安装 pymysql  sqlalchemy  scrapy#scrapy的piplines文件中fromsqlalchemyimportcreate_engine,text,insertimportpymysqlfromscrapy.utils.projectimportget_project_settingsclassMySQLPipeline:defopen_spider(self,spider):settings=......
  • Python旅游信息管理系统v7c4w(Pycharm Flask Django Vue mysql)
    文章目录项目介绍和开发技术介绍具体实现截图开发技术开发与测试:设计思路系统测试可行性分析核心代码部分展示文章目录/写作提纲参考源码/演示视频获取方式项目介绍和开发技术介绍旅游信息管理系统的现状来进行开发的,具体根据现实的需求来实现旅游信息管理系统网络......