跳到主要内容

Fuse Engine

引入或更新于:v1.2.617

Databend 使用 Fuse Engine 作为其默认引擎,提供了一个类似于 Git 的用户友好界面的数据管理系统。用户能够轻松地在任何时刻查询数据,并轻松地将数据恢复到任何所需的时间点。

语法

CREATE TABLE <table_name> (
<column_definitions>
) [ENGINE = FUSE]
[CLUSTER BY (<expr> [, <expr>, ...] )]
[<Options>];

有关 CREATE TABLE 语法的更多详细信息,请参见 CREATE TABLE

参数描述
ENGINE如果未明确指定引擎,Databend 将自动默认使用 Fuse Engine 创建表,这相当于 ENGINE = FUSE
CLUSTER BY指定由多个表达式组成的数据的排序方法。有关更多信息,请参见 Cluster Key
<Options>Fuse Engine 提供了多种选项(不区分大小写),允许您自定义表的属性。详情请参见 Fuse Engine 选项
- 多个选项之间用空格分隔。
- 使用 ALTER TABLE OPTION 修改表的选项。
- 使用 SHOW CREATE TABLE 显示表的选项。

Fuse Engine 选项

以下是可用的 Fuse Engine 选项:

选项语法描述
bloom_index_columnsbloom_index_columns = '<列> [, <列> ...]'指定用于布隆索引的列。这些列的数据类型可以是 Map、Number、String、Date 或 Timestamp。如果未指定特定列,则默认在所有支持的列上创建布隆索引。bloom_index_columns='' 会禁用布隆索引。
compressioncompression = '<压缩方法>'指定引擎的压缩方法。压缩选项包括 lz4、zstd、snappy 或 none。在对象存储中,压缩方法默认为 zstd,在文件系统(fs)存储中默认为 lz4。
storage_formatstorage_format = '<存储格式>'指定数据的存储方式。默认情况下,storage_format 设置为 Parquet,它提供了高压缩率,非常适合云原生对象存储。此外,还支持实验性的 Native 格式,优化了文件系统等存储设备的内存复制开销。
snapshot_locsnapshot_loc = '<snapshot_loc>'指定一个字符串格式的位置参数,允许轻松共享表而无需复制数据。
block_size_thresholdblock_size_threshold = <n>指定块的最大大小(以字节为单位)。默认为 104,857,600 字节。
block_per_segmentblock_per_segment = <n>指定一个段中的最大块数。默认为 1,000。
row_per_blockrow_per_block = <n>指定文件中的最大行数。默认为 1,000,000。
change_trackingchange_tracking = True / False在 Fuse Engine 中将此选项设置为 True 可以跟踪表的更改。
为表创建流会自动将 change_tracking 设置为 True,并向表中引入额外的隐藏列作为更改跟踪元数据。有关更多信息,请参阅 流的工作原理
data_retention_period_in_hoursdata_retention_period_in_hours = <n>指定表数据的保留时间(以小时为单位)。最小值为 1 小时。最大值由 databend-query.toml 配置文件中的 data_retention_time_in_days_max 设置定义,如果未指定,则默认为 2,160 小时(90 天 x 24 小时)。
开始使用 Databend Cloud
低成本
快速分析
多种数据源
弹性扩展
注册