MaxCompute中如何使用OSS外部表读取JSON数据?
2020-03-11 本文已影响0人
阿里云技术
一、打开OSS,上传json文件
data:image/s3,"s3://crabby-images/58443/58443477433f6e4ac56b967f2deef6d2c4cea2ad" alt=""
json文件内容展示:
{"id":5644228109524316032,"sourceType":1}{"id":-736866360508848202,"sourceType":3}
二、登录DataWorks,建立外部表
data:image/s3,"s3://crabby-images/366ee/366eefb4bea5b12931e5fe225c9d699f0fe0a5a8" alt=""
建表语句:
CREATE EXTERNAL TABLE `json_table` ( `id` bigint, `sourcetype` int) ROW FORMAT SERDE 'org.apache.hive.hcatalog.data.JsonSerDe'STORED AS TEXTFILELOCATION 'oss://oss-cn-beijing-internal.aliyuncs.com/gjt-demo/home/jsondata/';
三、建立临时查询,查看数据
data:image/s3,"s3://crabby-images/a0ea3/a0ea3595bdcab36e157da3a64931484401dd72ba" alt=""
需要设置的flag语句以及查询语句
set odps.sql.type.system.odps2=true;set odps.sql.hive.compatible=true;select * from json_table;
查询结果展示:
data:image/s3,"s3://crabby-images/d9ab2/d9ab20fa78c27b8581a53628eaec0cfd4c0104c7" alt=""