当前位置: 首页 > news >正文

doris: MAP数据类型

MAP<K, V> 表示由K, V类型元素组成的 map,不能作为 key 列使用。

  • 目前支持在 Duplicate,Unique 模型的表中使用。

K, V 支持的类型有:

BOOLEAN, TINYINT, SMALLINT, INT, BIGINT, LARGEINT, FLOAT, DOUBLE, DECIMAL, DECIMALV3,
DATE, DATEV2, DATETIME, DATETIMEV2, CHAR, VARCHAR, STRING

CSV格式导入​

第 1 步:准备数据​

创建如下的 csv 文件:test_map.csv 其中分隔符使用 | 而不是逗号,以便和 map 中的逗号区分。

1|{"Emily":101,"age":25}
2|{"Benjamin":102}
3|{}
4|null

第 2 步:在数据库中建表​

CREATE TABLE map_test (id       INT                 NOT NULL,c_map    MAP<STRING, INT>    NULL
)
DUPLICATE KEY(id)
DISTRIBUTED BY HASH(id) BUCKETS 1
PROPERTIES ("replication_allocation" = "tag.location.default: 1"
);

第 3 步:导入数据​

curl --location-trusted \-u "root":"" \-H "column_separator:|" \-H "columns: id, c_map" \-T "test_map.csv" \http://localhost:8040/api/testdb/map_test/_stream_load

第 4 步:检查导入数据​

mysql> SELECT * FROM map_test;
+------+-------------------------+
| id   | c_map                   |
+------+-------------------------+
|    1 | {"Emily":101, "age":25} |
|    2 | {"Benjamin":102}        |
|    3 | {}                      |
|    4 | NULL                    |
+------+-------------------------+
4 rows in set (0.01 sec)

JSON格式导入​

第 1 步:准备数据​

创建如下的 JSON 文件,test_map.json

[{"id":1, "c_map":{"Emily":101, "age":25}},{"id":2, "c_map":{"Benjamin":102}},{"id":3, "c_map":{}},{"id":4, "c_map":null}
]

第 2 步:在数据库中建表​

CREATE TABLE map_test (id       INT                 NOT NULL,c_map    MAP<STRING, INT>    NULL
)
DUPLICATE KEY(id)
DISTRIBUTED BY HASH(id) BUCKETS 1
PROPERTIES ("replication_allocation" = "tag.location.default: 1"
);

第 3 步:导入数据​

curl --location-trusted \-u "root":"" \-H "format:json" \-H "columns: id, c_map" \-H "strip_outer_array:true" \-T "test_map.json" \http://localhost:8040/api/testdb/map_test/_stream_load

第 4 步:检查导入数据​

mysql> SELECT * FROM map_test;
+------+-------------------------+
| id   | c_map                   |
+------+-------------------------+
|    1 | {"Emily":101, "age":25} |
|    2 | {"Benjamin":102}        |
|    3 | {}                      |
|    4 | NULL                    |
+------+-------------------------+
4 rows in set (0.01 sec)

http://www.lryc.cn/news/528370.html

相关文章:

  • Gurobi基础语法之 LinExpr 类
  • 《Java核心技术 卷II》日期和时间API的时间线
  • 文献阅读 250128-Tropical forests are approaching critical temperature thresholds
  • Deepseek的RL算法GRPO解读
  • Linux 如何使用fdisk进行磁盘相关的操作
  • 智能客服系统:结合 AI 模型与数据库实现对话与知识检索
  • 网易Android开发面试题200道及参考答案 (下)
  • 《哈佛家训》
  • 为AI聊天工具添加一个知识系统 之76 详细设计之17 正则表达式 之4 正则表达式模板
  • 面试被问的一些问题汇总(持续更新)
  • WS2812 梳理和颜色表示方法的对比:RGB和HSV
  • JAVA实战开源项目:蜗牛兼职平台(Vue+SpringBoot) 附源码
  • C++:多继承习题3
  • 【云安全】云原生-K8S-搭建/安装/部署
  • 06-AD向导自动创建P封装(以STM32-LQFP48格式为例)
  • linux监控脚本+自动触发邮件发送
  • 【漫话机器学习系列】066.贪心算法(Greedy Algorithms)
  • 代码随想录算法训练营第三十八天-动态规划-完全背包-279.完全平方数
  • ts 基础核心
  • 在RHEL 8.10上安装开源工业物联网解决方案Thingsboard 3.9
  • linux通过deb包安装(命令模式)
  • 「Unity3D」在Unity中使用C#控制显示Android的状态栏
  • LLM评估优化与新技术创新综述
  • 【Git】使用笔记总结
  • ZZNUOJ(C/C++)基础练习1000——1010(详解版)
  • 搜狐Android开发(安卓)面试题及参考答案
  • WPS数据分析000007
  • SpringCloud系列教程:微服务的未来(十八)雪崩问题、服务保护方案、Sentinel快速入门
  • 把markdown转换为pdf的方法
  • Controller 层优化四步曲