【DB吐槽大会】第15期 - PG 没有全局临时表

简介: 大家好,这里是DB吐槽大会,第15期 - PG 没有全局临时表

背景


1、产品的问题点

  • PG 没有全局临时表

2、问题点背后涉及的技术原理

  • PG 的临时表是使用时创建, 结构定义在1个会话内有效. 每次创建临时表时, 需要在pg_class, pg_stats, pg_attribute等元数据中插入临时表的对象数据、统计信息数据、字段定义数据等. 在会话结束是再从这些元数据表中删除.

3、这个问题将影响哪些行业以及业务场景

  • 频繁使用临时表的业务, 例如将业务逻辑放入数据库存储过程中, 使用临时表来存放一些中间计算结果.

4、会导致什么问题?

  • 元数据表、元数据表对应的索引膨胀.
  • 使用不便, 每次使用临时表都需要重新创建.

5、业务上应该如何避免这个坑

  • 目前带来的膨胀副作用基本无解.
  • 可以使用一些方法自动创建临时表, 而不需要每次创建
  • 使用array或者json代替temp table.

6、业务上避免这个坑牺牲了什么, 会引入什么新的问题

  • 管理成本增加
  • array, json的单值上限是1G, 有使用局限性.

7、数据库未来产品迭代如何修复这个坑

  • 有一些patch, 希望内核层支持全局临时表



相关文章
|
存储 传感器 监控
【DB吐槽大会】第1期——PG MVCC
大家好,这是DB吐槽大会,第1期 - PG MVCC
12417 0
|
关系型数据库 数据库 PostgreSQL
【DB吐槽大会】第38期 - PG 不能自动创建(扩展)分区
大家好,这里是DB吐槽大会,第38期 - PG 不能自动创建(扩展)分区
|
关系型数据库 数据库 索引
【DB吐槽大会】第32期 - PG 没有全局索引
大家好,这里是DB吐槽大会,第32期 - PG 没有全局索引
|
弹性计算 关系型数据库 数据库
【DB吐槽大会】第34期 - PG 全局catalog全局可见
大家好,这里是DB吐槽大会,第34期 - PG 全局catalog全局可见
|
SQL 关系型数据库 数据库
【DB吐槽大会】第75期 - PG 不支持索引失效功能
大家好,这里是DB吐槽大会,第75期 - PG 不支持索引失效功能
|
机器学习/深度学习 SQL 算法
【DB吐槽大会】第58期 - PG 复杂JOIN优化器有巨大提升空间
大家好,这里是DB吐槽大会,第58期 - PG 复杂JOIN优化器有巨大提升空间
|
SQL 消息中间件 存储
【DB吐槽大会】第33期 - PG 逻辑复制不支持DDL
大家好,这里是DB吐槽大会,第33期 - PG 逻辑复制不支持DDL
|
存储 关系型数据库 数据库
【DB吐槽大会】第53期 - PG 函数和存储过程没有版本管理
大家好,这里是DB吐槽大会,第53期 - PG 函数和存储过程没有版本管理
|
存储 SQL 缓存
【DB吐槽大会】第45期 - PG 不支持rotate表
大家好,这里是DB吐槽大会,第45期 - PG 不支持rotate表
|
JSON 固态存储 关系型数据库
【DB吐槽大会】第43期 - PG 倒排索引启动和recheck代价高
大家好,这里是DB吐槽大会,第43期 - PG 倒排索引启动和recheck代价高