AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 12077
Accepted
a_hardin
a_hardin
Asked: 2009-05-26 12:22:01 +0800 CST2009-05-26 12:22:01 +0800 CST 2009-05-26 12:22:01 +0800 CST

对所有表和索引启用行级压缩

  • 772

Works With SQL Server 2008 测试的(可选)要求之一是对所有表和索引启用行级压缩。我们有一个现有的数据库,其中已经创建了很多表和索引。有没有一种简单的方法可以对所有这些表和索引启用压缩?

这是我最终根据 splattne 的建议制作的脚本。

select 'ALTER TABLE [' + name + '] REBUILD WITH (DATA_COMPRESSION = ROW);'   
from   sysobjects   where  type = 'U' -- all user tables
UNION
select 'ALTER INDEX [' + k.name + '] ON [' + t.name + '] REBUILD WITH (DATA_COMPRESSION = ROW);'
from   sysobjects k
join sysobjects t on k.parent_obj = t.id
   where  k.type = 'K' -- all keys
    AND t.type = 'U' -- all user tables
sql-server-2008 compression
  • 5 5 个回答
  • 3815 Views

5 个回答

  • Voted
  1. Best Answer
    BillVo
    2010-03-07T09:58:30+08:002010-03-07T09:58:30+08:00

    我刚刚使用 Works With SQL Server Tool 在使用 a_hardin-splattne 脚本压缩后进行了测试。测试失败,因为几个索引没有被压缩。

    “sysobjects”视图包括一些但不是全部的索引。我们需要“sysindexes”来代替。感谢aspfaq.com上的匿名发帖人提供此索引见解。我们还想忽略用户定义的函数。

    SELECT 'ALTER TABLE [' + name + '] REBUILD WITH (DATA_COMPRESSION = ROW);' + CHAR(13) + CHAR(10) + 'GO' + CHAR(13) + CHAR(10) 
    FROM  sysobjects  WHERE type = 'U' -- all user tables
    UNION
    SELECT  'ALTER INDEX [' + i.name + '] ON [' + OBJECT_NAME(i.id) + '] REBUILD WITH (DATA_COMPRESSION = ROW);' + CHAR(13) + CHAR(10) + 'GO' + CHAR(13) + CHAR(10) 
    FROM 
        sysindexes i 
        inner join sysobjects o on o.name = OBJECT_NAME(i.id)
    WHERE 
        (i.indid BETWEEN 1 AND 254) 
        AND (i.Status & 64)=0 
        AND OBJECTPROPERTY(i.id, 'IsMsShipped') = 0 
        AND NOT o.type in ('TF','FN')
    
    • 4
  2. splattne
    2009-05-26T12:49:58+08:002009-05-26T12:49:58+08:00

    您可以使用这个简单的 SQL 脚本来创建另一个应该完成这项工作的脚本:

       select 'ALTER TABLE ' + name + ' REBUILD WITH (DATA_COMPRESSION = ROW)' 
             + CHAR(13) + CHAR(10) + 'GO'
       from   sysobjects
       where  type = 'U' -- all user tables
    

    (我没有对此进行测试,但它应该可以工作。)


    您可以在SQLServerBible 站点上找到更复杂的脚本(查找“db_compression procs”。)阅读作者的博客文章“Whole Database - Data Compression Procs”。

    • 3
  3. Paul Randal
    2009-05-28T09:29:31+08:002009-05-28T09:29:31+08:00

    顺便说一句,要小心使所有内容都被压缩。数据在内存中被压缩,每次访问时都会解压缩。对于具有大量更改和内存驻留数据的 OLTP 系统,压缩是不合适的,因为您将消耗更多 CPU 而不会增加 IO。对于偶尔读取的数据,例如数据仓库,它更合适,因为您可以在减少 IO 与额外 CPU 之间做出很大的权衡。压缩是一种数据仓库功能,而不是 OLTP 功能。不确定这是否适用于您,但值得指出以防万一,以及其他阅读该主题的人。

    另一点 - 可能是您没有从压缩中获得显着收益,因此不值得转出。在启用使用 sp_estimate_data_compression_savings 存储过程之前检查压缩增益的最佳实践。

    谢谢

    • 2
  4. Aaron Alton
    2009-05-26T20:04:40+08:002009-05-26T20:04:40+08:00

    您可能还应该考虑处理新表,因此您不需要定期运行此批处理。我在这篇博文中详细介绍了一种自动压缩新表的方法。

    我还提到您应该在重建表之前检查表是否被压缩。

    • 1
  5. knuckles
    2015-11-03T04:05:37+08:002015-11-03T04:05:37+08:00

    我参加聚会有点晚了,但这是一个使用 DMV 而不是已弃用的系统表并允许任意模式名称的版本。它启用或禁用当前数据库中所有堆、聚集索引和非聚集索引(包括所有分区表)的行或页面压缩:

    -- Enables or disables compression on all tables in the database
    DECLARE @Compression NVARCHAR(4) = 'PAGE' -- NONE, ROW or PAGE
        , @Cmd NVARCHAR(MAX) = '';
    
    -- Clustered indexes, heaps
    SELECT @Cmd +=  '
    ALTER TABLE ' + QUOTENAME(s.name) + '.' + QUOTENAME(t.name) + ' REBUILD ' + CASE WHEN p.[partition_number] > 1 THEN 'PARTITION = ALL ' ELSE '' END + 'WITH (DATA_COMPRESSION = ' + @Compression + ');'
    FROM sys.schemas s
        INNER JOIN sys.tables t ON t.[schema_id] = s.[schema_id]
        INNER JOIN sys.partitions p ON p.[object_id] = t.[object_id]
    WHERE p.[data_compression_desc] <> @Compression
        AND p.index_id IN (0, 1)
        AND NOT EXISTS (
            SELECT 1
            FROM sys.partitions d
            WHERE d.[object_id] = p.[object_id]
                AND d.index_id = p.index_id
                AND d.[partition_number] > p.[partition_number]
        );
    
    -- Nonclustered indexes
    SELECT @Cmd +=  '
    ALTER INDEX ' + QUOTENAME(i.name) + ' ON ' + QUOTENAME(s.name) + '.' + QUOTENAME(t.name) + ' REBUILD ' + CASE WHEN p.[partition_number] > 1 THEN 'PARTITION = ALL ' ELSE '' END + 'WITH (DATA_COMPRESSION = ' + @Compression + ');'
    FROM sys.schemas s
        INNER JOIN sys.tables t ON t.[schema_id] = s.[schema_id]
        INNER JOIN sys.partitions p ON p.[object_id] = t.[object_id]
        INNER JOIN sys.indexes i ON i.[object_id] = p.[object_id] AND i.index_id = p.index_id
    WHERE p.[data_compression_desc] <> @Compression
        AND p.index_id > 1
        AND NOT EXISTS (
            SELECT 1
            FROM sys.partitions d
            WHERE d.[object_id] = p.[object_id]
                AND d.index_id = p.index_id
                AND d.[partition_number] > p.[partition_number]
        );
    
    -- Review commands
    SELECT @Cmd;
    
    -- Run commands
    --EXEC sp_executesql @Cmd;
    
    • 0

相关问题

  • SQL Server 文件本地或 NAS 或 SAN?

  • 使用 SQL Server 2008 中的现有数据重置主键列?

  • 将管理员用户添加到 SQL Server 2008

  • IIS 6.0 (Windows Server 2003) 上的 HTTP 压缩

  • 如何从 SQL Server 2008 中的备份中排除索引

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve