RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 802080
Accepted
Алекс Лизенберг
Алекс Лизенберг
Asked:2020-03-20 21:48:16 +0000 UTC2020-03-20 21:48:16 +0000 UTC 2020-03-20 21:48:16 +0000 UTC

postgresql 告诉我如何创建压缩的 TOAST 列?

  • 772

有一个带有 BATEA 字段的表,其中数据、xml 文件被压缩,以节省空间。也就是说,一个样本,我们将它们解压缩并发布它们。

但是我们了解到,似乎有某种 TOAST 字段类型,您可以以明文形式存储数据,而 postgres 本身会负责它们的压缩。

这是https://www.postgresql.org/docs/9.4/static/storage-toast.html

告诉我它是如何创建的?没找到例子,不知道怎么创建常规的文本列,但是压缩了

CREATE TABLE "table" (
    "ID" INTEGER NOT NULL,
    "txt" TEXT TOAST ??????? , 
    PRIMARY KEY ("ID")
) 
postgresql
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    Мелкий
    2020-03-20T23:02:28Z2020-03-20T23:02:28Z

    TOAST它不是数据类型。一般来说,事实上,这是一个拐杖。在较低级别,这些行被放置在 8kb 块 - 页中(原则上,不一定是 8kb,这是一个编译时选项 - 但我从未见过它改变)。并且整条数据线的大小不能超过8kb。根本不可能,这是一个硬限制。但是如果用户想要保存更多的东西 - 他可以做到。在这种情况下,数据被透明地分割为用户的部分,并存储在单独的服务toast表中。一路上,他们可能会尝试压缩——据我所知,那里使用的压缩算法速度很快,而且压缩效果不是很好。

    这完全自动发生,唯一可用的设置是可以通过以下方式选择4 种策略之一ALTER TABLE SET STORAGE:

    • PLAIN禁止压缩和移除toast
    • EXTENDED允许压缩和toast制表
    • EXTERNAL禁止压缩,但允许单独存储
    • MAIN启用压缩,仅在没有其他帮助的情况下将数据与字符串分开存储

    另外,我注意到没有需要压缩数据或将其放置在 toast 表中的设置。小数据不会被单独压缩或渲染。

    据我所知,toast所有的变长数据类型都可以取出来:text、varchar、arrays、json、jsonb、xml、hstore等。C 中数据类型的实现知道 的使用toast,所以我不能说toast所有可变长度数据类型使用什么,但至少对于大多数 - 肯定。

    也就是说,如果您使用大于 2kb 的 bytea,则您已经拥有并使用了 toast。本机压缩算法是否会比您当前使用的更紧凑 - 我对此表示怀疑,但您可以通过实验进行检查。

    • 3

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    是否可以在 C++ 中继承类 <---> 结构?

    • 2 个回答
  • Marko Smith

    这种神经网络架构适合文本分类吗?

    • 1 个回答
  • Marko Smith

    为什么分配的工作方式不同?

    • 3 个回答
  • Marko Smith

    控制台中的光标坐标

    • 1 个回答
  • Marko Smith

    如何在 C++ 中删除类的实例?

    • 4 个回答
  • Marko Smith

    点是否属于线段的问题

    • 2 个回答
  • Marko Smith

    json结构错误

    • 1 个回答
  • Marko Smith

    ServiceWorker 中的“获取”事件

    • 1 个回答
  • Marko Smith

    c ++控制台应用程序exe文件[重复]

    • 1 个回答
  • Marko Smith

    按多列从sql表中选择

    • 1 个回答
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Suvitruf - Andrei Apanasik 什么是空? 2020-08-21 01:48:09 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

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

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5