大数据StarRocks(七):数据表创建

在这里插入图片描述

1. 基本概念

1.1 Row & Column

一张表包括行(Row)和列(Column)。Row 即用户的一行数据。Column 用于描述一行数据中不同的字段。
⚫ 在默认的数据模型中,Column 只分为排序列和非排序列。存储引擎会按照排序列对数据进行排序存储,并建立稀疏索引,以便在排序数据上进行快速查找。
⚫ 而在聚合模型中,Column 可以分为两大类:Key 和 Value。从业务角度看,Key 和Value 可以分别对应维度列和指标列。从聚合模型的角度来说,Key 列相同的行,会聚合成一行。其中 Value 列的聚合方式由用户在建表时指定。

1.2 Partition & Tablet

在 Doris 的存储引擎中,用户数据首先被划分成若干个分区(Partition),划分的规则通常是按照用户指定的分区列进行范围划分,比如按时间划分。而在每个分区内,数据被进一步的按照 Hash 的方式分桶,分桶的规则是要找用户指定的分桶列的值进行 Hash 后分桶。每个分桶就是一个数据分片(Tablet),也是数据划分的最小逻辑单元。
⚫ Tablet 之间的数据是没有交集的,独立存储的。Tablet 也是数据移动、复制等操作的最小物理存储单元。
⚫ Partition 可以视为是逻辑上最小的管理单元。数据的导入与删除,都可以或仅能针对一个 Partition 进行。

2. OLAP表定义

建表的基本语法

CREATE [EXTERNAL] TABLE [IF NOT EXISTS] [database.]table_name
(column_definition1[, column_definition2, ...]
[, index_definition1[, index_definition2, ...]])
[ENGINE = [olap|mysql|elasticsearch|hive|iceberg|hudi|jdbc]]
[key_desc]
[COMMENT "table comment"]
[partition_desc]
[distribution_desc]
[rollup_index]
[ORDER BY (column_definition1,...)]
[PROPERTIES ("key"="value", ...)]
[BROKER PROPERTIES ("key"="value", ...)]

参数说明

2.1 表分为内部表和外部表

默认未内部表,3.0版本开始集成外部数据建议使用catalog,外部表的建表方式将被弃用

2.2 列定义

语法:

col_name col_type [agg_type] [NULL | NOT NULL] [DEFAULT "default_value"] [AUTO_INCREMENT] [AS generation_expr]
col_name:列名称

注意,在一般情况下,不能直接创建以以 __op 或 __row 开头命名的列,因为此类列名被 StarRocks 保留用于特殊目的,创建这样的列可能导致未知行为。如需创建这样的列,必须将 FE 动态参数 allow_system_reserved_names 设置为 TRUE。

col_type:列数据类型

之前博文数据类型

agg_type:聚合类型,如果不指定,则该列为 key 列。否则,该列为 value 列。

支持的聚合类型如下:

  • SUM、MAX、MIN、REPLACE

  • HLL_UNION(仅用于 HLL列,为 HLL 独有的聚合方式)。

  • BITMAP_UNION(仅用于 BITMAP 列,为 BITMAP 独有的聚合方式)。

  • REPLACE_IF_NOT_NULL:这个聚合类型的含义是当且仅当新导入数据是非 NULL 值时会发生替换行为。如果新导入的数据是 NULL,那么 StarRocks 仍然会保留原值。

注意:

BITMAP_UNION 聚合类型列在导入时的原始数据类型必须是 TINYINT, SMALLINT, INT, BIGINT。
如果在建表时 REPLACE_IF_NOT_NULL 列指定了 NOT NULL,那么 StarRocks 仍然会将其转化 NULL,不会向用户报错。用户可以借助这个类型完成「部分列导入」的功能。 该类型只对聚合模型有用 (key_desc 的 type 为 AGGREGATE KEY)。
NULL | NOT NULL:列数据是否允许为 NULL。其中明细模型、聚合模型和更新模型表中所有列都默认指定 NULL。主键模型表的指标列默认指定 NULL,维度列默认指定 NOT NULL。如源数据文件中存在 NULL 值,可以用 \N 来表示,导入时 StarRocks 会将其解析为 NULL。

DEFAULT “default_value”:列数据的默认值。导入数据时,如果该列对应的源数据文件中的字段为空,则自动填充 DEFAULT 关键字中指定的默认值。支持以下三种指定方式:

DEFAULT current_timestamp:默认值为当前时间。参见 current_timestamp() 。
DEFAULT <默认值>:默认值为指定类型的值。例如,列类型为 VARCHAR,即可指定默认值为 DEFAULT “beijing”。当前不支持指定 ARRAY、BITMAP、JSON、HLL 和 BOOLEAN 类型为默认值。
DEFAULT (<表达式>):默认值为指定函数返回的结果。目前仅支持 uuid() 和 uuid_numeric() 表达式。
AUTO_INCREMENT:指定自增列。自增列的数据类型只支持 BIGINT,自增 ID 从 1 开始增加,自增步长为 1。有关自增列的详细说明,请参见 AUTO_INCREMENT。自 v3.0,StarRocks 支持该功能。

AS generation_expr:指定生成列和其使用的表达式。生成列用于预先计算并存储表达式的结果,可以加速包含复杂表达式的查询。自 v3.1,StarRocks 支持该功能。

2.3 键的描述

语法:

`key_type(k1[,k2 ...])`

数据按照指定的 key 列进行排序,且根据不同的 key_type 具有不同特性。 key_type 支持以下类型:

AGGREGATE KEY: key 列相同的记录,value 列按照指定的聚合类型进行聚合,适合报表、多维分析等业务场景。
UNIQUE KEY/PRIMARY KEY: key 列相同的记录,value 列按导入顺序进行覆盖,适合按 key 列进行增删改查的点查询 (point query) 业务。
DUPLICATE KEY: key 列相同的记录,同时存在于 StarRocks 中,适合存储明细数据或者数据无聚合特性的业务场景。
默认为 DUPLICATE KEY,数据按 key 列做排序。

除 AGGREGATE KEY 外,其他 key_type 在建表时,value 列不需要指定聚合类型 (agg_type)。

2.4 分布式描述​

支持随机分桶(Random bucketing)和哈希分桶(Hash bucketing)。如果不指定分桶信息,则 StarRocks 默认使用随机分桶且自动设置分桶数量。

DISTRIBUTED BY RANDOM BUCKETS <num>

不支持主键模型表、更新模型表和聚合表。
不支持指定 Colocation Group。
不支持 Spark Load。
自 2.5.7 版本起,建表时无需手动指定分桶数量,StarRocks 自动设置分桶数量。

DISTRIBUTED BY HASH (k1[,k2 ...]) [BUCKETS num]

如果查询比较复杂,则建议选择高基数的列为分桶键,保证数据在各个分桶中尽量均衡,提高集群资源利用率。
如果查询比较简单,则建议选择经常作为查询条件的列为分桶键,提高查询效率。 并且,如果数据倾斜情况严重,您还可以使用多个列作为数据的分桶键,但是建议不超过 3 个列。

建表时,必须指定分桶键。
作为分桶键的列,该列的值不支持更新。
分桶键指定后不支持修改。
自 2.5.7 版本起,建表时无需手动指定分桶数量,StarRocks 自动设置分桶数量。

2.5 PROPERTIES

设置数据的初始存储介质、自动降冷时间和副本数​
如果 ENGINE 类型为 OLAP,可以在属性 properties 中设置该表数据的初始存储介质(storage_medium)、自动降冷时间(storage_cooldown_time)或者时间间隔(storage_cooldown_ttl)和副本数(replication_num)。

属性生效范围:当表为单分区表时,以上属性为表的属性。当表划分成多个分区时,以上属性属于每一个分区。并且如果希望不同分区有不同属性,则建表后可以执行 ALTER TABLE … ADD PARTITION 或 ALTER TABLE … MODIFY PARTITION。

设置数据的初始存储介质、自动降冷时间

PROPERTIES (
    "storage_medium" = "[SSD|HDD]",
    { "storage_cooldown_ttl" = "<num> { YEAR | MONTH | DAY | HOUR } "
    | "storage_cooldown_time" = "yyyy-MM-dd HH:mm:ss" }
)

目前 StarRocks 提供如下数据自动降冷的相关参数,对比如下:
storage_cooldown_ttl:表的属性,指定该表中分区自动降冷时间间隔,由系统自动降冷表中到达时间点(时间间隔+分区时间上界)的分区。并且表按照分区粒度自动降冷,更加灵活。
storage_cooldown_time:表的属性,指定该表的自动降冷时间点(绝对时间)。建表后也可以为不同分区配置不同时间点。
storage_cooldown_second:FE 静态参数,指定集群范围内所有表的自动降冷时延。
表属性 storage_cooldown_ttl 或 storage_cooldown_time 比 FE 静态参数 storage_cooldown_second 优先级高。
配置以上参数时,必须指定 "storage_medium = “SSD”。
不配置以上参数时,则不进行自动降冷。
执行 SHOW PARTITIONS FROM <table_name> 查看各个分区的自动降冷时间点。

不支持表达式分区和 List 分区。
不支持分区列为非日期类型。
不支持多个分区列。
不支持主键模型表。
设置分区 Tablet 副本数
replication_num:分区 Tablet 副本数。默认为 3。

PROPERTIES (
    "replication_num" = "<num>"
)

创建表时为列添加 bloom filter 索引​

如果 Engine 类型为 olap, 可以指定某列使用 bloom filter 索引。bloom filter 索引使用时有如下限制:
主键模型和明细模型中所有列都可以创建 Bloom filter 索引;聚合模型和更新模型中,只有维度列(即 Key 列)支持创建 Bloom filter 索引。
不支持为 TINYINT、FLOAT、DOUBLE 和 DECIMAL 类型的列创建 Bloom filter 索引。
Bloom filter 索引只能提高查询条件为 in 和 = 的查询效率,值越分散效果越好。

PROPERTIES (
    "bloom_filter_columns" = "k1, k2, k3"
)

添加属性支持 Colocate Join​
如果希望使用 Colocate Join 特性,需要在 properties 中指定:

PROPERTIES (
    "colocate_with" = "table1"
)

设置动态分区​
如果希望使用动态分区特性,需要在 properties 中指定如下参数:

PROPERTIES (
    "dynamic_partition.enable" = "true|false",
    "dynamic_partition.time_unit" = "DAY|WEEK|MONTH",
    "dynamic_partition.start" = "${integer_value}",
    "dynamic_partition.end" = "${integer_value}",
    "dynamic_partition.prefix" = "${string_value}",
    "dynamic_partition.buckets" = "${integer_value}"
)

设置随机分桶表中分桶大小​
自 3.2 版本起,对于随机分桶的表,您可以在建表时在 PROPERTIES 中设置 bucket_size 参数来指定分桶大小,启用按需动态增加分桶数量。单位为 B。

PROPERTIES (
    "bucket_size" = "1073741824"
)

设置数据压缩算法​
您可以在建表时通过增加属性 compression 为该表指定数据压缩算法。
compression 有效值包括:
LZ4:LZ4 算法。
ZSTD:Zstandard 算法。
ZLIB:zlib 算法。
SNAPPY:Snappy 算法。
如不指定数据压缩算法,StarRocks 默认使用 LZ4。

  • 19
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 《大数据大创新:云上数据中台之道》是一本关于大数据和云计算的书籍,旨在探讨如何通过构建数据中台实现企业的数字化转型和创新发展。 首先,该书说明了大数据和云计算对于企业的重要性和价值。大数据作为一种新的生产要素,可以帮助企业挖掘数据中蕴藏的商业价值,并于竞争中获得优势。而云计算作为一种灵活的计算和存储方式,为企业提供了高效、可扩展和经济的解决方案。 接着,书中介绍了构建数据中台的关键要素和方法。数据中台是一种基于云计算的数据管理平台,将企业内外部的各种数据进行整合和管理,形成一套完整的数据体系。通过数据中台,企业可以实现数据的集中管理、整理和加工,从而实现数据共享和分析,为企业的决策提供有效支持。 此外,书中还提供了一些成功案例和最佳实践。通过分析这些案例,读者可以了解到企业在利用大数据和云计算方面的具体做法和效果。这些案例涵盖了不同行业和领域,旨在帮助读者了解如何根据自身需求和条件进行实践和创新。 最后,该书还强调了数据中台建设的挑战和未来发展趋势。由于大数据和云计算技术的快速进步和应用,数据中台正面临着各种挑战和机遇。此书通过对挑战的分析和展望,为企业提供了一些建设数据中台的思路和方法,并对未来的发展趋势给出了一定的预测。 总而言之,《大数据大创新:云上数据中台之道》是一本关于大数据和云计算的实践指南,旨在通过构建数据中台实现企业的数字化转型和创新发展,为企业和个人对大数据和云计算技术有兴趣的读者提供了宝贵的参考和指导。 ### 回答2: 《大数据大创新:云上数据中台之道》是一本关于大数据和创新的书籍,重点讲述了云上数据中台的运作方式和方法。 云上数据中台是指将企业内部、外部以及合作伙伴的各类数据整合和利用起来,在云端建立一个统一的数据中心,实现数据的共享、协同和挖掘,从而帮助企业进行创新和决策。 这本书深入浅出地介绍了云上数据中台的基本概念和架构,以及如何建立和运营一个高效的数据中台。它提供了一系列实用的案例和方法,帮助读者了解如何从海量的数据中提取有价值的信息,并将其应用于企业的决策和创新过程中。 通过云上数据中台,企业可以更快速地获取和分析数据,实现数据的精准管理和使用。这有助于企业加快创新步伐,提高市场竞争力。同时,云上数据中台还可以帮助企业进行精细化运营,优化资源配置,实现成本降低和效益最大化。 《大数据大创新:云上数据中台之道》还介绍了云上数据中台的发展趋势和未来的挑战,为读者提供了对未来数据领域的思考和展望。它为广大企业家、管理人员和数据从业者提供了一份宝贵的参考资料和指导。 总之,本书全面而深入地介绍了云上数据中台的概念、架构和应用,并通过实用案例和方法帮助读者掌握相关技术和工具,使其能够在大数据时代中更好地创新和决策。它是一本对于大数据和创新感兴趣的人士非常有价值的读物。 ### 回答3: 《大数据大创新:云上数据中台之道》是一本介绍大数据和数据中台领域的书籍,其中包含了对云上数据中台发展的思考和实践经验。 大数据是当前快速发展的领域,通过收集、存储和分析海量数据,可以为企业提供更深入的洞察和决策支持。而数据中台作为大数据的基础设施,是连接各个业务系统和数据源的枢纽,能够实现数据的集成、共享和加值。 该书首先介绍了大数据和数据中台的基本概念和发展趋势。随着云计算技术的成熟和普及,云上数据中台成为了大数据发展的重要方向。云上数据中台能够提供弹性的计算和存储资源,解决了传统数据中台的资源瓶颈问题。 接着,书中详细分析了云上数据中台的架构和关键技术。云上数据中台需要建立高效可靠的数据集成、数据治理和数据分析能力。同时,还需要关注数据安全和隐私保护的问题。书中给出了一些实际案例和解决方案,帮助读者更好地理解和应用云上数据中台。 该书还探讨了云上数据中台与创新的关系。通过云计算、人工智能和物联网等技术的结合,云上数据中台能够为企业创新带来更多的机会。通过对大数据的挖掘和分析,可以发现新的商业模式和增长点,促进企业的创新和竞争力。 总的来说,《大数据大创新:云上数据中台之道》是一本介绍大数据和数据中台领域的实用性书籍,对于想要了解和应用云上数据中台的人来说,是一本值得阅读的参考书。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值