Apache Doris 数据类型全面解析:从基础到高级应用
2025-06-27 09:24:53作者:廉皓灿Ida
一、数据类型概述
Apache Doris 作为一款高性能的MPP分析型数据库,提供了丰富的数据类型支持,以满足不同业务场景下的数据处理需求。本文将系统性地介绍Doris支持的所有数据类型,包括数值类型、日期时间类型、字符串类型、半结构化类型、聚合类型以及IP类型,帮助开发者更好地理解和使用这些数据类型。
二、数值类型详解
1. 布尔类型(BOOLEAN)
布尔类型是最基础的数据类型之一,在Doris中:
- 使用1表示true
- 使用0表示false
这种表示方式与大多数编程语言一致,便于理解和转换。
2. 整数类型
Doris提供了从1字节到16字节的完整整数类型系列:
| 类型 | 存储空间 | 取值范围 | 典型应用场景 |
|---|---|---|---|
| TINYINT | 1字节 | -128 ~ 127 | 状态码、小范围计数 |
| SMALLINT | 2字节 | -32,768 ~ 32,767 | 中等范围计数 |
| INT | 4字节 | -2,147,483,648 ~ 2,147,483,647 | 常规整数存储 |
| BIGINT | 8字节 | -9.22×10¹⁸ ~ 9.22×10¹⁸ | 大整数、ID等 |
| LARGEINT | 16字节 | -2¹²⁷ ~ 2¹²⁷-1 | 超大整数、精确计算 |
选择建议:根据实际数据范围选择最小够用的类型,可以节省存储空间并提升查询性能。
3. 浮点类型
Doris支持两种浮点类型:
- FLOAT:单精度浮点,约7位有效数字
- DOUBLE:双精度浮点,约15位有效数字
注意:浮点类型存在精度损失问题,不适合金融等需要精确计算的场景。
4. 定点类型(DECIMAL)
DECIMAL类型用于精确计算,特别适合金融领域:
- 可指定精度和小数位数
- 不会产生浮点运算的精度误差
- 语法:DECIMAL(P,S),P表示总位数,S表示小数位数
三、日期时间类型
1. 主要类型
| 类型 | 精度 | 格式示例 | 特点 |
|---|---|---|---|
| DATE | 天 | '2023-01-01' | 仅存储日期 |
| DATETIME | 微秒 | '2023-01-01 12:00:00' | 存储日期和时间 |
| TIME | 秒 | '12:00:00' | 仅存储时间(暂不支持建表) |
2. 使用建议
- 避免直接将日期时间类型转为数值类型操作
- 使用内置函数处理日期计算:
- TIME_TO_SEC:时间转秒数
- DATE_DIFF:计算日期差
- UNIX_TIMESTAMP:获取Unix时间戳
四、字符串类型
1. 类型对比
| 类型 | 长度特性 | 最大长度 | 存储特点 |
|---|---|---|---|
| CHAR(M) | 固定长度 | 255字节 | 不足长度会填充空格 |
| VARCHAR(M) | 可变长度 | 65,533字节 | 只存储实际内容 |
| STRING | 可变长度 | 默认1MB(可配置) | 大文本存储 |
2. 选择策略
- 确定长度的字段使用CHAR(M)效率更高
- 长度变化大的字段使用VARCHAR(M)节省空间
- 超大文本使用STRING类型
五、半结构化类型
1. 固定模式类型
- ARRAY:存储同类型元素集合
- MAP:键值对集合
- STRUCT:复合结构,可包含不同类型字段
优势:固定模式带来高性能,适合分析场景。
2. 灵活模式类型
- VARIANT:自动扩展JSON结构为列存储
- 高压缩率
- 适合日志、IoT等半结构化数据
- JSON:二进制存储格式
- 点查询性能提升2倍以上
- 适合高并发查询场景
六、聚合类型
1. 主要类型及用途
| 类型 | 主要用途 | 优势 |
|---|---|---|
| BITMAP | 精确去重(UV统计) | 空间效率高,计算快 |
| HLL | 近似去重 | 比COUNT DISTINCT更快 |
| QUANTILE_STATE | 近似分位数计算 | 性能优于PERCENTILE函数 |
| AGG_STATE | 加速聚合计算 | 与聚合函数组合使用 |
七、IP类型
1. 类型特点
- IPv4:4字节存储,配套ipv4_*函数族
- IPv6:16字节存储,配套ipv6_*函数族
优势:相比字符串存储,查询更快且更节省空间。
八、最佳实践建议
- 数值类型:根据范围选择最小够用的类型
- 字符串类型:优先使用VARCHAR,固定长度用CHAR
- 日期类型:使用专门函数处理,避免直接数值转换
- 半结构化数据:
- 模式固定:使用ARRAY/MAP/STRUCT
- 模式灵活:查询为主用JSON,分析为主用VARIANT
- 去重统计:优先考虑BITMAP和HLL类型
通过合理选择数据类型,可以显著提升Doris的存储效率和查询性能。建议在实际应用中根据具体业务场景和数据特点选择最适合的类型。
登录后查看全文
热门项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00- QQwen3-Coder-Next2026年2月4日,正式发布的Qwen3-Coder-Next,一款专为编码智能体和本地开发场景设计的开源语言模型。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin08
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
热门内容推荐
最新内容推荐
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
531
3.74 K
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
336
178
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
886
596
Ascend Extension for PyTorch
Python
340
403
暂无简介
Dart
772
191
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
openJiuwen agent-studio提供零码、低码可视化开发和工作流编排,模型、知识库、插件等各资源管理能力
TSX
986
247
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
416
4.21 K
React Native鸿蒙化仓库
JavaScript
303
355