开发者社区 > PolarDB开源 > PolarDB 分布式版 > 正文

PolarDB列存节点仍会根据cost进行分流最后走行存索引吗?

如果执行 select from data 会走列存索引,那么 insert into data2 select from data 里面的查询会走列存索引吗?

展开
收起
小小爱吃香菜 2024-01-02 22:29:33 71 0
3 条回答
写回答
取消 提交回答
  • 面对过去,不要迷离;面对未来,不必彷徨;活在今天,你只要把自己完全展示给别人看。

    对于这个问题,从一般情况来看,INSERT INTO data2 SELECT * FROM data这样的查询不会走列存索引。因为这种查询语句是复制来源表的所有数据到目标表中,但并不会复制来源表的索引、约束以及触发器等信息。

    然而,如果数据量超过100k条记录,那么这些数据进入Row Group时会进行列压缩;没有超过100k条记录的数据则进入Delta Store(Delta Row group)。此外,如果你想将数据加载到列存储索引进行分析,你可能需要使用标准的SQL大容量加载和渗透插入方法。

    总的来说,是否走列存索引取决于你的具体需求和操作方式。如果你的目标是利用列存索引进行分析,那么你可能需要采取一些特定的策略或方法。

    2024-01-03 13:12:17
    赞同 展开评论 打赏
  • HBR混合云备份服务确实提供了将本地或云上资源备份到混合云备份的云上备份仓库的功能,并会按量计费。费用项目包括软件使用费、存储容量费、仓库租用费及流量费用等。此外,需要注意的是,如果您需要从备份数据中恢复数据,可能会产生数据恢复费用,该费用根据恢复数据的大小和恢复时间来计算。

    对于您的问题一,执行select from data会走列存索引,那么insert into data2 select from data里面的查询也会走列存索引。因为HBR混合云备份服务支持多种场景的数据源备份,包括线下物理机、VMWare/Hyperv平台虚拟机、云上虚拟机备份、以及基于workflow的其他数据源备份等。所以无论是简单的查询还是复杂的查询,只要涉及到的数据存储类型支持列存索引,那么查询就会走列存索引。

    对于您的问题二,当开启ETL功能后,本来走行存索引的简单查询发送到列存节点后,列存节点会根据查询的成本进行分流,最后可能会选择走行存索引。因为ETL功能可以提供强大的数据转换和加载能力,但同时也需要考虑数据的安全性和可用性,所以在实际操作中需要根据实际需求进行合理的备份策略设计。

    对于您的问题三,同样是因为ETL功能的引入,可能会导致本来走行存索引的简单查询发送到列存节点后,列存节点仍会根据查询的成本进行分流,最后可能会选择走行存索引。这也是为了确保数据的安全性和可用性,避免因为索引选择不当导致的数据访问效率问题。

    2024-01-03 09:01:00
    赞同 展开评论 打赏
  • 可以参考这个
    https://help.aliyun.com/zh/polardb/polardb-for-mysql/user-guide/etl-from-imci?spm=a2c4g.11186623.0.0.61534e033Kwvbq
    此回答整理自钉群“PolarDB专家面对面 - HTAP(列存索引)”

    2024-01-02 23:34:35
    赞同 展开评论 打赏

PolarDB 分布式版 (PolarDB for Xscale,简称“PolarDB-X”) 采用 Shared-nothing 与存储计算分离架构,支持水平扩展、分布式事务、混合负载等能力,100%兼容MySQL。 2021年开源,开源历程及更多信息访问:OpenPolarDB.com/about

相关电子书

更多
PolarDB+AnalyticDB助力交通物流行业系统升级 立即下载
PolarDB NL2SQL: 帮助您写出准确、优化的SQL 立即下载
云栖大会:开源 PolarDB 架构演进、关键技术与社区建设 立即下载